时间:2021-05-20
1.引用类型约束
struct RefSample<T> where T:class引用类型用Class表示约束,其他的引用类型为具体的约束。
表示对于的约束必须为一个类(引用类型)不能是值类型(int,char,datatime,struct),可以是接口interface
区分,数组为引用类型,因为定义数组时需要new出一个对象。
虽然定义成 RefSample<T> 传入的必须为引用类型 但是RefSample仍然为值类型
2.值类型约束
class ValSample<T> where T:struct
为引用类型,因为int,char等类型都是struct
ValSample<int>
3.构造函数类型约束
public T CreateInstance<T>() where T:new(){ return new T();}指定的类型T必须有构造函数,CreateInstance<int>和CreateInstance<object> 都是有效的。但是CreateInstance<strings>没有构造函数。
4.转换类型约束
一种约束允许你指定另一个类型,类型实参必须可以通过一致性、引用或装箱转换隐式地转换为该类型。你还可以规定一个类型实参必须可以转换为另一个类型实参——这称为类型参数约束。
理解的意思:可以互换,就是我们可以通过装箱或者强制类型转换成目标类型的 类型都可以用于类型参数传入。
class Sample<T> where T:Stream
有效:Sample<Stream> 这本身符合约束
无效:Sample<String> 因为String类型无法通过引用或者装箱拆箱强制转换成Stream、
struct Sample<T> where T:IDisposable
规定T必须为IDisposable 类型的 引用类型
有效:Sample<SqlConnection>引用转换
无效:Sample<StringBuilder>
分析:为什么SqlConnection 可以而StringBuilder不可以?它们都是引用类型
1.SqlConnection实现了IDisposable接口,所以可以协变
2.StringBuilder只实现了ISerializable接口,无法通过途径转换为IDisposable
class Sample<T> where T:IComparable<T>
因为将IComparable<T>整体当作约束,分析IComparable<T>的类型,可以用Type.IsValueType判断,true为值类型,false为引用类型
typeof(IComparable<T>).IsValueType结果为false表示为引用类型
有效:Sample<int>(装箱转换)
无效:Sample<FileInfo>
也可以指定多种约束:
class sample<T> where T:stream,IEnumerable<string>,IComparable<int>
class Sample<T,U> where T:U
有效:Sample<Stream,IDisposable>
无效:Sample<string,IDiposable>
总结:要看传入类参数是否可以转换,查看规定参数和传入类参数是否实现同一接口,如果实现则可以,否则不可以。
不可以是以下:System.Object,System.Enum,System.ValueType,System.Delegate,结构或密封类(String)
5.组合约束
对类型参数的约束有多个,注意:只能是一种类型,值类型和引用类型不能同时存在,没用一个类型即是引用类型,又是值类型。
由于每一个值类型都有一个无构造函数,此后不能再有构造函数约束
有效:
class Sample<T> where T:class,IDisposable,new()
class Sample<T,U> where T:Stream where U:IDispsable
无效:
class Sample<T> where T:class,struct (没有任何类型即时引用类型又是值类型的,所以为无效的)
class Sample<T> where T:Stream,class (引用类型约束应该为第一个约束,放在最前面,所以为无效的) Stream只是约束传入参数为Stream具体类型,而class约束为引用类型,一开始我理解错了
class Sample<T> where T:new(),Stream (new() 必须放在最后)
class Sample<T> where T:IDisposable,Stream (类必须放在接口前面,所以为无效的)
class Sample<T> where T:XmlReader,IComparable,IComparable (对于转换类型约束,同一个接口不能出现多次)
class Sample<T,U> where T:struct where U:Class,T (类型形参“T”具有“struct”约束,因此“T”不能用作“U”的约束,所以为无效的)
class Sample<T,U> where T:Stream ,U:IDisposable 语法错误
看到网上还有这种版本也是有效的我表示不理解:
class Sample<T> where T:struct,IDisapsable IDisapsable为值类型?
class Sample<T,U> where T:class where U:struct ,T T为引用类型为何与值类型一起约束U?
希望可以指正
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
一、泛型的基本概念java与c#一样,都存在泛型的概念,及类型的参数化。java中的泛型是在jdk5.0后出现的,但是java中的泛型与C#中的泛型是有本质区别
上篇文章给大家介绍了浅析C#中的类型系统(值类型和引用类型),接下来通过本文给大家介绍下c#泛型类型,说下C#中的泛型,熟练地使用泛型能提高代码的重用性,使用我
前言Kotlin泛型的基本语法类似于Java,不过出于型变安全,不支持Java中的,通配符型变约束,而是采用类似C#的in,out用于支持协变和逆变,这同时避免
在C#中,new关键字可用作运算符、修饰符或约束。new运算符用于创建对象和调用构造函数。new修饰符用于向基类成员隐藏继承成员。new约束用于在泛型声明中约束
本文以实例形式讲述了C#泛型的用法,有助于读者深入理解C#泛型的原理,具体分析如下:首先需要明白什么时候使用泛型:当针对不同的数据类型,采用相似的逻辑算法,为了