一.先来说说数组的不足
也可以说集合与数组的区别
1.数组是固定大小的,不能伸缩。虽然system.array.resize这个泛型方法可以重置数组大小,但是该方法是重新创建新设置大小的数组,用的是旧数组的元素初始化。随后以前的数组就废弃!而集合却是可变长的
2.数组要声明元素的类型,集合类的元素类型却是object.
3.数组可读可写不能声明只读数组。集合类可以提供readonly方法以只读方式使用集合。
4.数组要有整数下标才能访问特定的元素,然而很多时候这样的下标并不是很有用。集合也是数据列表却不使用下标访问。很多时候集合有定制的下标类型,对于队列和栈根本就不支持下标访问!
二.下面讲述6种常用集合
1.arraylist类
using system;
using system.collections.generic;
using system.text;
using system.collections;
namespace consoleapplication1
{
class program
{
static void main(string[] args)
{
arraylist al = new arraylist();
al.add(100);//单个添加
foreach (int number in new int[6] { 9, 3, 7, 2, 4, 8 })
{
al.add(number);//集体添加方法一//清清月儿 http://blog.csdn.net/21aspnet/
}
int[] number2 = new int[2] { 11,12 };
al.addrange(number2);//集体添加方法二
al.remove(3);//移除值为3的
al.removeat(3);//移除第3个
arraylist al2 = new arraylist(al.getrange(1, 3));//新arraylist只取旧arraylist一部份
console.writeline("遍历方法一:");
foreach (int i in al)//不要强制转换
{
console.writeline(i);//遍历方法一
}
console.writeline("遍历方法二:");
for (int i = 0; i != al2.count; i++)//数组是length
{
int number = (int)al2[i];//一定要强制转换
console.writeline(number);//遍历方法二
}
}
}
}

2.stack类
栈,后进先出。push方法入栈,pop方法出栈。
using system;
using system.collections.generic;
using system.text;
using system.collections;
namespace consoleapplication1
{
class program
{
static void main(string[] args)
{
stack sk = new stack();
stack sk2 = new stack();
foreach (int i in new int[4] { 1, 2, 3, 4 })
{
sk.push(i);//填充
sk2.push(i);
}
foreach (int i in sk)
{
console.writeline(i);//遍历
}
sk.pop();
console.writeline("pop");
foreach (int i in sk)
{
console.writeline(i);
}
sk2.peek();//弹出最后一项不删除//清清月儿 http://blog.csdn.net/21aspnet/
console.writeline("peek");
foreach (int i in sk2)
{
console.writeline(i);
}
while (sk2.count != 0)
{
int i = (int)sk2.pop();//清空
sk2.pop();//清空
}
console.writeline("清空");
foreach (int i in sk2)
{
console.writeline(i);
}
}
}
}

3.queue类
队列,先进先出。enqueue方法入队列,dequeue方法出队列。
using system;
using system.collections.generic;
using system.text;
using system.collections;
namespace consoleapplication1
{
class program
{
static void main(string[] args)
{
queue qu = new queue();
queue qu2 = new queue();
foreach (int i in new int[4] { 1, 2, 3, 4 })
{
qu.enqueue(i);//填充
qu2.enqueue(i);
}
foreach (int i in qu)
{
console.writeline(i);//遍历
}
qu.dequeue();
console.writeline("dequeue");
foreach (int i in qu)
{
console.writeline(i);
}
qu2.peek();//弹出最后一项不删除
console.writeline("peek");
foreach (int i in qu2)
{
console.writeline(i);
}
while (qu2.count != 0)
{
int i = (int)qu2.dequeue();//清空
qu2.dequeue();//清空
}
console.writeline("清空");
foreach (int i in qu2)
{
console.writeline(i);
}
}
}
}

4.hashtable类
哈希表,名-值对。类似于字典(比数组更强大)。哈希表是经过优化的,访问下标的对象先散列过。如果以任意类型键值访问其中元素会快于其他集合。gethashcode()方法返回一个int型数据,使用这个键的值生成该int型数据。哈希表获取这个值最后返回一个索引,表示带有给定散列的数据项在字典中存储的位置。
using system;
using system.collections.generic;
using system.text;
using system.collections;
namespace consoleapplication1
{
class program
{
public static void main()
{
// creates and initializes a new hashtable.
hashtable myht = new hashtable();
myht.add("one", "the");
myht.add("two", "quick");
myht.add("three", "brown");
myht.add("four", "fox");
// displays the hashtable.//清清月儿 http://blog.csdn.net/21aspnet/
console.writeline("the hashtable contains the following:");
printkeysandvalues(myht);
}
public static void printkeysandvalues(hashtable myht)
{
foreach (string s in myht.keys)
console.writeline(s);
console.writeline(" -key- -value-");
foreach (dictionaryentry de in myht)
console.writeline(" {0}: {1}", de.key, de.value);
console.writeline();
}
}
}

5.sortedlist类
与哈希表类似,区别在于sortedlist中的key数组排好序的。
using system;
using system.collections.generic;
using system.text;
using system.collections;
namespace consoleapplication1
{
class program
{
public static void main()
{
sortedlist sl = new sortedlist();
sl["c"] = 41;
sl["a"] = 42;
sl["d"] = 11;
sl["b"] = 13;
foreach (dictionaryentry element in sl)
{
string s = (string)element.key;
int i = (int)element.value;
console.writeline("{0},{1}",s,i);
}
}
}
}

6.namevaluecollection类
官方给namevaluecollection定义为特殊集合一类,在system.collections.specialized下。
system.collections.specialized下还有hybriddicionary类,建议少于10个元素用hybriddicionary,当元素增加会自动转为hashtable。
system.collections.specialized下还有hybriddicionary类,字符串集合。
system.collections.specialized下还有其他类大家可以各取所需!
言归正转主要说namevaluecollection,hashtable 和 namevaluecollection很类似但是他们还是有区别的,hashtable 的key是唯一性,而namevaluecollection则不唯一!
using system;
using system.collections.generic;
using system.collections;
using system.collections.specialized;
namespace consoleapplication1
{
class program
{
static void main(string[] args)
{
system.collections.hashtable ht = new system.collections.hashtable();
ht.add("ddpmdisplayseq".trim(), "display sequence".trim());
ht.add("ddpmnamechi".trim(), "name (chinese)".trim());
ht.add("ddpmnameeng".trim(), "name (english)".trim());
ht.add("comment".trim(), "comment".trim());
ht.add("ddpmmarketcode".trim(), "market code".trim());
foreach (object key in ht.keys)
{
console.writeline("{0}/{1} {2},{3}", key, ht[key], key.gethashcode(), ht[key].gethashcode());
}
console.writeline(" ");//清清月儿 http://blog.csdn.net/21aspnet/
namevaluecollection mycol = new namevaluecollection();
mycol.add("ddpmdisplayseq".trim(), "display sequence".trim());
mycol.add("ddpmnamechi".trim(), "name (chinese)".trim());
mycol.add("ddpmnamechi".trim(), "name (english)".trim());
mycol.add("comment".trim(), "comment".trim());
mycol.add("ddpmmarketcode".trim(), "market code".trim());
foreach (string key in mycol.keys)
{
console.writeline("{0}/{1} {2},{3}", key, mycol[key], key.gethashcode(), mycol[key].gethashcode());
}
}
}
}

到此这篇关于c#中6种常用集合类小结的文章就介绍到这了,更多相关c#常用集合类内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论