泛型总结

泛型

一、泛型体验

泛型是framework 2.0加入的一种特殊的算法重用机制,允许程序员在代码中将变量的类型先用类型占位符来替代,等到运行的时候在根据传入的类来替换。

Demo1

MyList类:

 1 public class MyList<T>
 2     {
 3         T[] arr;
 4         public int count=0;
 5         public MyList(int length)
 6         {
 7             arr = new T[length];
 8         }
 9         public void Add(T t)
10         {
11             arr[count] = t;
12             count++;
13         }
14 
15         /// <summary>
16         /// 索引器
17         /// </summary>
18         /// <param name="index"></param>
19         /// <returns></returns>
20         public T this[int index]
21         {
22             get
23             {
24                 if (index >= arr.Length)
25                 {
26                     throw new System.Exception("数组下标越界");
27                 }
28                 else
29                 {
30                     return arr[index];
31                 }
32             }
33               set
34             {
35                 if (index >= arr.Length)
36                 {
37                     throw new System.Exception("数组下标越界");
38                 }
39                 else
40                 {
41                     arr[index]=value;
42                 }
43             }
44         }
45     }
View Code

调用:

 1  protected void Page_Load(object sender, EventArgs e)
 2         {
 3             MyList<int> list = new MyList<int>(4);
 4             
 5             list.Add(1);
 6             list.Add(4);
 7             list.Add(5);
 8             list.Add(6);
 9             for (int i = 0; i < list.count; i++)
10             {
11                 Response.Write(list[i].ToString());
12             }
13         }
View Code

注意:

1、 是在运行时,将堆空间里的对象内部所有的占位符都替换成传入的类型.

2、 泛型是指带类型参数的类,而不是类型参数本身。

如:public class MyList<T>{..} 其实MyList就是泛型,而T是类型参数。

3、 clr编译时,编译器只为MyList<T>类型产生“泛型版”的IL代码------并不进行泛型的实例化,T在中间只充当占位符。

4、 执行的时候,当jit编译器第一次遇到MyList<int>时,将用int替代”泛型版”IL代码与源数据中的T------进行泛型类型的实例化。

5、 实例化一个引用类型的泛型,它在内存中分配的大小是一样的,实例化一个值类型的时候,在内存中分配的大小是不一样的,尽管如此,clr还是为每个不同的类型参数创建了不同的泛型类版本。

二、泛型类

1、多个类型参数用逗号隔开

  

2、泛型类的继承

     继承一个泛型类的时候,必须为父类传递泛型参数

     可以指定一个具体的参数类型:public class Son:Father<int,string>

     可以把子类的泛型参数赋值给父类泛型参数class Son<w,y>:Father<w,y>

三、泛型约束

构造器约束:Demo2

MyDog类:

1  public class MyDog<T> where T:new()//泛型约束,传进来的T类型必须有无参数的构造函数,不能约束是否有带参数的构造函数
2     {
3         T t;
4         public MyDog()
5         {
6             t = new T();
7         }
8     }
View Code

调用:

1  protected void Page_Load(object sender, EventArgs e)
2         {
3             MyDog<LittleDog> dog = new MyDog<LittleDog>();
4         }

基类约束:用来约束泛型参数必须是某个类的子类,一个泛型参数不允许多少基类约束,不能为密封类指定基类约束(string)。

值类型约束:public class C<T> where T:struct

引用类型约束:public class C<T> where T:class

四、泛型方法

1、泛型方法的泛型参数,可以用在该方法的形参、方法体、返回值三处。

1 public K Test<k>(K a) where K:new()
2 
3 {
4 
5    K k1=new K();
6 
7    return k1;
8 
9 }

2、泛型方法的重载

1 void SayB<T>{}
2 
3 //void SayB<S>{}//和上面的实质一样,不构成重载
4 
5 void SayB<T,T2>{}
6 
7 void SayB<T>(string name)
8 
9 //void SayB<T>(): where T:class //泛型类型约束不构成重载的条件

3、泛型方法的重写

 1 public class Father
 2 
 3 {
 4 
 5 public virtual T Shout<T>() where T:new()
 6 
 7     {
 8 
 9        return new T();
10 
11 }
12 
13 }
14 
15 public class Son:Father
16 
17 {
18 
19    public override T Shout<t>()//在父类中设置了构造函数约束,子类中就不需要再约束了,T的名字即使不一样,也可以
20 
21    {
22   return new T();
23 
24 }
25 
26 }
View Code

------------------------------------------------------------------------------------------------------------------------------------------

 软谋在线教育,最适合大学生、上班族的在线软件培训,主要教授asp.net动态网站制作,yy教育房间远程实时授课,每节课录制成高清视频课后分享,老师白天八小时全职在线辅导,不懂就问。加qq群:138800420 即可免费试听。

转载于:https://www.cnblogs.com/ruanmou001/p/3628747.html

【博士论文复现】【阻抗建模、验证扫频法】光伏并网逆变器扫频与稳定性分析(包含锁相环电流环)(Simulink仿真实现)内容概要:本文档围绕“博士论文复现”主题,重点介绍了光伏并网逆变器的阻抗建模与扫频法稳定性分析,涵盖锁相环和电流环的Simulink仿真实现。文档旨在通过完整的仿真资源和代码帮助科研人员复现相关技术细节,提升对新能源并网系统动态特性和稳定机制的理解。此外,文档还提供了大量其他科研方向的复现资源,包括微电网优化、机器学习、路径规划、信号处理、电力系统分析等,配套MATLAB/Simulink代码与模,服务于多领域科研需求。; 适合人群:具备一定电力电子、自动控制或新能源背景的研究生、博士生及科研人员,熟悉MATLAB/Simulink环境,有志于复现高水平论文成果并开展创新研究。; 使用场景及目标:①复现光伏并网逆变器的阻抗建模与扫频分析过程,掌握其稳定性判据与仿真方法;②借鉴提供的丰富案例资源,支撑博士论文或期刊论文的仿真实验部分;③结合团队提供的算法与模,快速搭建实验平台,提升科研效率。; 阅读建议:建议按文档目录顺序浏览,优先下载并运行配套仿真文件,结合理论学习与代码调试加深理解;重点关注锁相环与电流环的建模细节,同时可拓展学习其他复现案例以拓宽研究视野。
内容概要:本文系统解析了嵌入式通信协议栈系列项目的实践路径,围绕通信原理与工程实现,阐述在资源受限的嵌入式环境中构建稳定、可扩展通信能力的方法。文章从通信基础模出发,强调分层设计思想,涵盖物理层到应用层的职责划分,并依次讲解通信驱动、数据收发机制、帧格式解析、状态机控制、错误处理等核心技术环节。项目实践注重底层可靠性建设,如中断响应、缓冲区管理与数据校验,同时关注上层应用对接,确保协议栈支持设备配置、状态上报等实际业务。文中还突出性能优化与资源管理的重要性,指导开发者在内存与处理效率间取得平衡,并通过系统化测试手段(如异常模拟、压力测试)验证协议栈的健壮性。; 适合人群:具备嵌入式系统基础知识,有一定C语言和硬件接口开发经验,从事或希望深入物联网、工业控制等领域1-3年工作经验的工程师。; 使用场景及目标:①掌握嵌入式环境下通信协议栈的分层架构设计与实现方法;②理解状态机、数据封装、异常处理等关键技术在真实项目中的应用;③提升在资源受限条件下优化通信性能与稳定性的工程能力; 阅读建议:建议结合实际嵌入式平台动手实践,边学边调,重点关注各层接口定义与模块解耦设计,配合调试工具深入分析通信流程与异常行为,以全面提升系统级开发素养。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值