博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【框架设计】泛型的应用
阅读量:5139 次
发布时间:2019-06-13

本文共 6755 字,大约阅读时间需要 22 分钟。

       在日常编码工作中,我们追求高效的代码。需要的是高性能可重用的代码,而非重复的代码。那么泛型则显得尤为方便.其显著的特点是重用代码,保护类型和提高性能.并且在泛型使用过程中减少装箱操作.泛型可以用途广泛,可根据需求创建泛型接口,泛型委托,泛型类,泛型方法,泛型集合.但是却不能创建泛型枚举!下面认识下什么是泛型,以及泛型有哪些类型和优点.最后依旧采用小实例的演练走进泛型的世界.


什么是泛型?

泛型是类型参数化以达到代码复用,提高软件开发效率和提高性能的数据类型.System.Collections.Generic命名空间下包含大量泛型集合和泛型集合类.

通常可定义为:

public class MyClass
{//类体}

一般使用:

MyClass<T> MyClassObj=new MyClass<T>();

泛型特点有哪些?

1,可重用性:例如,咱们要做个排序功能,中间有一个数据交换的方法Swap(参数),如果多个不同类型排序,那么你需要定义多个Swap方法.但是这种冗余的编程方法太糟糕了,那么就可以利用泛型设Swap(T),每次调用根据T不同调用方法.

2,高效性:例如,对一个数组集合添加不同类型成员(string,int),如果是值类型添加需要装箱,读取拆箱.这样大大降低性能(大量数据).但是泛型集合通过JIT编译时生成使用时类型,不在进行拆箱和装箱.

3,类型安全:例如,对集合添加不同类型信息,非泛型集合可以添加任意类型,不加约束,以至于有时候不能通过编译和异常.但是泛型集合有约束,必须统一类型,相对安全很多.

List<T>泛型集合有哪些操作?

方法:Find:搜索指定匹配元素,并返回第一个查找结果.

FindAll:检索指定匹配的所有元素结果.

FindIndex:已重载,返回第一个匹配项索引.

FindLast:返回指定最后一个元素结果

FindLastIndex:返回指定的最后一个结果索引.

FCL中泛型集合对于哪些非泛型集合?

List<T>-------ArrayList                   Dictionary<Tkey,TValue>-------Hashtable

SortedDictionary<TKey,TValue>---------SortedList             Stack<T>-----Stack

Queue<T>-----Queue                    LinkedList<T>----无

泛型接口和泛型接口类有哪些?

IList<T>------IList                         IDictionary------------IDictionary

ICollection-------ICollection             IEnumerator<T>------- IEnumerator

 IEnumerable<T>------- IEnumerable    IComparer<T>-------- IComparer

 ICompable<T>---- ICompable

泛型集合实例演练:

实现一个简易电话本信息,运行后显示联系人姓名,点击详细信息,在文本框显示所有信息。可以实现详细信息,添加,删除,统计人数,退出等功能。

定义类PhoneBook

class PhoneBook    {        public string name { get; set; }        public string phoneNum { get; set; }        public string Type { get; set; }        public  PhoneBook(string name, string phoneNum, string Type)        {            this.name = name;            this.phoneNum = phoneNum;            this.Type = Type;        }    }

 

填充数据方法:

private void FillList(List
phonebooks) { LV1.Items.Clear(); foreach (PhoneBook phonebook in phonebooks) { ListViewItem item = new ListViewItem(phonebook.name); item.SubItems.AddRange(new string[] { phonebook.phoneNum, phonebook.Type }); LV1.Items.Add(item); } }

客户端详细信息:

public partial class Form1 : Form    {        public Form1()        {            InitializeComponent();        }        private void FillList(List
phonebooks) { LV1.Items.Clear(); foreach (PhoneBook phonebook in phonebooks) { ListViewItem item = new ListViewItem(phonebook.name); item.SubItems.AddRange(new string[] { phonebook.phoneNum, phonebook.Type }); LV1.Items.Add(item); } } List
phonebooks; private void Form1_Load(object sender, EventArgs e) { phonebooks = new List
(); PhoneBook zhang = new PhoneBook("张三", "16543789089", "诺基亚"); PhoneBook li = new PhoneBook("李四","16543789089","HTC"); PhoneBook wang = new PhoneBook("王五", "16543789089","苹果"); PhoneBook bai = new PhoneBook("白柳", "16543789089", "HTC"); PhoneBook zhou = new PhoneBook("周长", "16543789089", "苹果"); phonebooks.Add(zhang); phonebooks.Add(li); phonebooks.Add(wang); phonebooks.Add(bai); phonebooks.Add(zhou); FillList(phonebooks); } private void butAdd_Click(object sender, EventArgs e) { if (String.IsNullOrEmpty(tbName.Text) || String.IsNullOrEmpty(tbPhone.Text) || String.IsNullOrEmpty(tbType.Text)) { MessageBox.Show("添加信息不能为空!", "错误", MessageBoxButtons.OK, MessageBoxIcon.Error); } PhoneBook phone = new PhoneBook(tbName.Text, tbPhone.Text, tbType.Text); phonebooks.Add(phone); FillList(phonebooks); tbName.Text = ""; tbPhone.Text = ""; tbType.Text = ""; } private void butDetail_Click(object sender, EventArgs e) { if (LV1.SelectedItems.Count == 0) { MessageBox.Show("没有选中选择项!"); return; } int index = LV1.SelectedItems[0].Index; tbName.Text = phonebooks[index].name; tbPhone.Text = phonebooks[index].phoneNum; tbType.Text = phonebooks[index].Type; FillList(phonebooks); } private void butDel_Click(object sender, EventArgs e) { if (LV1.SelectedItems.Count == 0) { MessageBox.Show("没有选中选择项!"); return; } int index = LV1.SelectedItems[0].Index; phonebooks.RemoveAt(index); FillList(phonebooks); tbName.Text = ""; tbPhone.Text = ""; tbType.Text = ""; } private void butExit_Click(object sender, EventArgs e) { Dispose(); } private void butTotal_Click(object sender, EventArgs e) { string count = string.Format("总共有{0}个电话信息。",phonebooks.Count.ToString()); MessageBox.Show(count); } }

运行结果(点击详细信息和统计):


DicTionary<K,V>泛型集合类实现上面功能:

设计添加信息的核心代码:

Dictionary
phonebooks; private void FillList(Dictionary
phonebooks) { LV1.Items.Clear(); foreach (PhoneBook phonebook in phonebooks.Values) { ListViewItem item = new ListViewItem(phonebook.name); item.SubItems.AddRange(new string[] { phonebook.phoneNum, phonebook.Type }); LV1.Items.Add(item); } }

窗体加载核心部分代码:

private void Form1_Load(object sender, EventArgs e)        {            phonebooks = new Dictionary
(); PhoneBook zhang = new PhoneBook("张三", "16543789089", "诺基亚"); PhoneBook li = new PhoneBook("李四", "16543789089", "HTC"); PhoneBook wang = new PhoneBook("王五", "16543789089", "苹果"); phonebooks.Add(zhang.name,zhang); phonebooks.Add(li.name,li); phonebooks.Add(wang.name,wang); FillList(phonebooks); }

运行结果:同上;


泛型接口:

public class NameComparer : IComparer
{ //实现姓名升序排列 public int Compate(PhoneBook x,PhoneBook y) { return (x.name.CompareTo(y.name)); } }}

自定义接口:

interface IMyList
{ //接口方法; }

泛型类:(为演示where后面代码如此,应一个类型)

class Myclass
where T : struct|class//该类类型是值类型或引用类型 { //具体实现 }

类型方法:

public string GetInfo
() { return result; }

总结:

      关于泛型操作,本文只是简单演示大概要点和基本使用,深入的研究下泛型是有必要的.应为在项目开发中,使用泛型+反射技术是一件很爽的事情,虽然我应用还不熟练.并且在有时候操作上会带来意想不到的惊喜.一代简介高效可重用的代码,是如此的迷人和享受.继续探索的路上行走!

转载于:https://www.cnblogs.com/baiboy/archive/2013/03/22/2976430.html

你可能感兴趣的文章
【Linux】ping命令详解
查看>>
8、RDD持久化
查看>>
第二次团队冲刺--2
查看>>
[转载]加密算法库Crypto——nodejs中间件系列
查看>>
使用Xshell密钥认证机制远程登录Linux
查看>>
【模板】最小生成树
查看>>
网络编程
查看>>
java面试题
查看>>
pair的例子
查看>>
uva 387 A Puzzling Problem (回溯)
查看>>
Oracle中包的创建
查看>>
django高级应用(分页功能)
查看>>
【转】Linux之printf命令
查看>>
关于PHP会话:session和cookie
查看>>
display:none和visiblity:hidden区别
查看>>
C#double转化成字符串 保留小数位数, 不以科学计数法的形式出现。
查看>>
利用IP地址查询接口来查询IP归属地
查看>>
构造者模式
查看>>
Hbuild在线云ios打包失败,提示BuildConfigure Failed 31013 App Store 图标 未找到 解决方法...
查看>>
找到树中指定id的所有父节点
查看>>