C#List用法 数据库设计与实现

DEMO:

private voidbtnTestList_Click(object sender, EventArgs e)
{
string[] temArr = { "Ha", "Hunter", "Tom", "Lily", "Jay", "Jim","Kuku", "Locu" };
List<string> testList = newList<string>(temArr);
testList.Add("Zzw");//增加一个元素
int s2 = testList.Count;
testList.Insert(1, "Zzh");//插入一个元素
C#List用法 数据库设计与实现
testList.AddRange(temArr);//增加一组元素
testList.Remove("Jim");//删除一个值,如果有重复,则删除排在前面的值
testList.RemoveAt(3);//删除指定下标的值
testList.RemoveRange(3, 2);//从下表index开始,删除指定count个数的值
foreach (string str in testList)
{
//MessageBox.Show(str);//遍历List中的元素
}
if (testList.Contains("Zzw"))
{
//MessageBox.Show("存在Zzw");
}
testList.Sort();//给List里的元素排序
//testList.Clear();//清空List里的元素

//搜索与指定谓词所定义的条件相匹配的元素,并返回整个List中的第一个匹配元素
//直到搜索完全部元素,都没有找到,则listFind为null
//委托为一个函数或一个拉姆达表达式
string listFind = "";//string.Empty;
listFind = testList.Find(name =>
{
if (name.Length > 10)
{
return true;
}
return false;
});

string listFind2 = testList.Find(ListFind); //委托为ListFind函数
//搜索与指定谓词所定义的条件相匹配的元素,并返回整个List中最后一个匹配元素
//从最后一个元素开始找,找到匹配的元素即可
string listFind3 = testList.FindLast(ListFind);

//确定是否List中的每个元素都与指定的谓词所定义的条件相匹配
//委托给表达式和函数
bool flag = testList.TrueForAll(name =>
{
if (name.Length > 3)
{
return true;
}
else
{
return false;
}
});

//检索与指定谓词所定义的条件相匹配的所有元素
List<string> subList =testList.FindAll(ListFind);//委托给ListFind函数

//检索与指定谓词所定义的条件相匹配的所有元素,和FindAll类似
IEnumerable<string> whereList =testList.Where(name =>
{
if (name.Length > 3)
{ return true; }
else
{ return false; }
});

//移除与指定的谓词所定义的条件相匹配的所有元素
subList.RemoveAll(name =>
{
if (name.Length > 4)
{
return true;
}
else
{
return false;
}
});

}

public bool ListFind(string name)
{
if (name.Length > 3)
{
return true;
}
return false;
}

C#List<T>用法

所属命名空间:System.Collections.Generic

publicclassList<T>:IList<T>,ICollection<T>,IEnumerable<T>,IList,ICollection,IEnumerable

List<T>类是ArrayList类的泛型等效类。该类使用大小可按需动态增加的数组实现IList<T>泛型接口。

泛型的好处:它为使用c#语言编写面向对象程序增加了极大的效力和灵活性。不会强行对值类型进行装箱和拆箱,或对引用类型进行向下强制类型转换,所以性能得到提高。

性能注意事项:

在决定使用IList<T>还是使用ArrayList类(两者具有类似的功能)时,记住IList<T>类在大多数情况下执行得更好并且是类型安全的。

如果对IList<T>类的类型T使用引用类型,则两个类的行为是完全相同的。但是,如果对类型T使用值类型,则需要考虑实现和装箱问题。

用微软的话讲:

“添加到ArrayList中的任何引用或值类型都将隐式地向上强制转换为Object。如果项是值类型,则必须在将其添加到列表中时进行装箱操作,在检索时进行取消装箱操作。强制转换以及装箱和取消装箱操作都会降低性能;在必须对大型集合进行循环访问的情况下,装箱和取消装箱的影响非常明显。”

1、List的基础、常用方法:

声明:

1、List<T>mList=newList<T>();

T为列表中元素类型,现在以string类型作为例子

E.g.:List<string>mList=newList<string>();

2、List<T>testList=newList<T>(IEnumerable<T>collection);

以一个集合作为参数创建List

E.g.:

string[]temArr={"Ha","Hunter","Tom","Lily","Jay","Jim","Kuku","Locu"};

List<string>testList=newList<string>(temArr);

添加元素:

1、List.Add(Titem)添加一个元素

E.g.:mList.Add("John");

2、List.AddRange(IEnumerable<T>collection)添加一组元素

E.g.:

string[]temArr={"Ha","Hunter","Tom","Lily","Jay","Jim","Kuku","Locu"};

mList.AddRange(temArr);

3、Insert(intindex,Titem);在index位置添加一个元素

E.g.:mList.Insert(1,"Hei");

遍历List中元素:

foreach(TelementinmList)T的类型与mList声明时一样

{

Console.WriteLine(element);

}

E.g.:

foreach(stringsinmList)

{

Console.WriteLine(s);

}

删除元素:

1、List.Remove(Titem)删除一个值

E.g.:mList.Remove("Hunter");

2、List.RemoveAt(intindex);删除下标为index的元素

E.g.:mList.RemoveAt(0);

3、List.RemoveRange(intindex,intcount);

从下标index开始,删除count个元素

E.g.:mList.RemoveRange(3,2);

判断某个元素是否在该List中:

List.Contains(Titem)返回true或false,很实用

E.g.:

if(mList.Contains("Hunter"))

{

Console.WriteLine("ThereisHunterinthelist");

}

else

{

mList.Add("Hunter");

Console.WriteLine("AddHuntersuccessfully.");

}

给List里面元素排序:

List.Sort()默认是元素第一个字母按升序

E.g.:mList.Sort();

给List里面元素顺序反转:

List.Reverse()可以与List.Sort()配合使用,达到想要的效果

E.g.:mList.Sort();

List清空:List.Clear()

E.g.:mList.Clear();

获得List中元素数目:

List.Count()返回int值

E.g.:

intcount=mList.Count();

Console.WriteLine("Thenumofelementsinthelist:"+count);

2、List的进阶、强大方法:

举例用的List:

string[]temArr={Ha","Hunter","Tom","Lily","Jay","Jim","Kuku",""Locu"};

mList.AddRange(temArr);

List.Find方法:搜索与指定谓词所定义的条件相匹配的元素,并返回整个List中的第一个匹配元素。

publicTFind(Predicate<T>match);

Predicate是对方法的委托,如果传递给它的对象与委托中定义的条件匹配,则该方法返回true。当前List的元素被逐个传递给Predicate委托,并在List中向前移动,从第一个元素开始,到最后一个元素结束。当找到匹配项时处理即停止。

Predicate可以委托给一个函数或者一个拉姆达表达式

委托给拉姆达表达式:

E.g.:

stringlistFind=mList.Find(name=>//name是变量,代表的是mList

{//中元素,自己设定

if(name.Length>3)

{

returntrue;

}

returnfalse;

});

Console.WriteLine(listFind);//输出是Hunter

委托给一个函数:

E.g.:

stringlistFind1=mList.Find(ListFind);//委托给ListFind函数

Console.WriteLine(listFind);//输出是Hunter

ListFind函数:

publicboolListFind(stringname)

{

if(name.Length>3)

{

returntrue;

}

returnfalse;

}

这两种方法的结果是一样的。

List.FindLast方法:搜索与指定谓词所定义的条件相匹配的元素,并返回整个List中的最后一个匹配元素。

publicTFindLast(Predicate<T>match);

用法与List.Find相同。

List.TrueForAll方法:确定是否List中的每个元素都与指定的谓词所定义的条件相匹配。

publicboolTrueForAll(Predicate<T>match);

委托给拉姆达表达式:

E.g.:

boolflag=mList.TrueForAll(name=>

{

if(name.Length>3)

{

returntrue;

}

else

{

returnfalse;

}

}

);

Console.WriteLine("Trueforall:"+flag);//flag值为false

委托给一个函数,这里用到上面的ListFind函数:

E.g.:

boolflag=mList.TrueForAll(ListFind);//委托给ListFind函数

Console.WriteLine("Trueforall:"+flag);//flag值为false

这两种方法的结果是一样的。

List.FindAll方法:检索与指定谓词所定义的条件相匹配的所有元素。

publicList<T>FindAll(Predicate<T>match);

E.g.:

List<string>subList=mList.FindAll(ListFind);//委托给ListFind函数

foreach(stringsinsubList)

{

Console.WriteLine("elementinsubList:"+s);

}

这时subList存储的就是所有长度大于3的元素

List.Take(n):获得前n行返回值为IEnumetable<T>,T的类型与List<T>的类型一样

E.g.:

IEnumerable<string>takeList=mList.Take(5);

foreach(stringsintakeList)

{

Console.WriteLine("elementintakeList:"+s);

}

这时takeList存放的元素就是mList中的前5个

List.Where方法:检索与指定谓词所定义的条件相匹配的所有元素。跟List.FindAll方法类似。

E.g.:

IEnumerable<string>whereList=mList.Where(name=>

{

if(name.Length>3)

{

returntrue;

}

else

{

returnfalse;

}

});

foreach(stringsinsubList)

{

Console.WriteLine("elementinsubList:"+s);

}

这时subList存储的就是所有长度大于3的元素

List.RemoveAll方法:移除与指定的谓词所定义的条件相匹配的所有元素。

publicintRemoveAll(Predicate<T>match);

E.g.:

mList.RemoveAll(name=>

{

if(name.Length>3)

{

returntrue;

}

else

{

returnfalse;

}

});

foreach(stringsinmList)

{

Console.WriteLine("elementinmList:"+s);

}

这时mList存储的就是移除长度大于3之后的元素。

  

爱华网本文地址 » http://www.413yy.cn/a/25101017/365761.html

更多阅读

数据库设计的三大范式 数据库设计的几大范式

过去我设计的数据库产品虽然可以使用,但是都是很不科学的数据库,大量存在数据冗余,或者管理不方便。在大学的课程中我终于明白一个比较科学的数据库设计需要满足些什么标准,这就是每个数据库的设计都必须满足三大范式的要求。1.三大范

基于ST L6562的120W PFC线路设计与实现 l6562d引脚功能

摘要:为了使AC/DC电源在满足IEC61000-3-2谐波标准的同时能够实现低成本、高性能,对单级功率因数校正技术(PFC)的需求越来越紧迫,特别是小功率场合。本文按照不同划分原则对PFC技术分类讨论,指出单级PFC技术适用于小功率场合,是PFC技术在

远程心电监护软件系统的设计与实现 操作系统设计与实现

1 引言心血管疾病是现代工业社会中对人类生命威胁最大的疾病,我国城镇中现有4000多万冠心病患者。由于心脏疾病发病时具有很大的突然性,失去了宝贵的早期诊断救治时间,导致疾病进入晚期,甚至当场发生心脏猝死,造成高额医疗费用,给社

收盘集合竞价设计与股价操纵 港股收盘集合竞价

收盘集合竞价设计与股价操纵(上海证券交易所研究中心2006 年9 月)以集合竞价作为收盘机制迎合了指数化投资的发展趋势,并且可确保市场压力状态下的价格发现过程。因此,目前主要证券交易所收盘机制有逐步改为集合竞价的趋势。..集合

声明:《C#List用法 数据库设计与实现》为网友清白小生分享!如侵犯到您的合法权益请联系我们删除