集合

作者: TALY | 来源:发表于2017-12-26 20:56 被阅读0次

首先 会联系到相关的数组类型

但是数组有两个不能改变

1.存入的内容必须需要统一变量类型(除非使用object数组,但是需要不断的拆装箱)

2.申明数组时候必须至少给予长度,长度是固定。(在相同的数组中无法添加减少)

而集合的优势就是:

处理的对象组可根据程序更改的需要动态地增长和收缩。 对于某些集合,您可以为放入该集合的任何对象分配一个“键”,以便使用该键快速检索对象。

集合分为两大类:泛型集合与非泛型集合

使用非泛型集合的 需引入:System.Collections命名空间。

使用泛型集合需引入:System.Collections.Generic命名空间。

栈 和 队列

适用于的情况多是 存在需要存入一组需要先入后出(栈)

或是需要一组先入先出(队列)的 数据结构 且都是有 方向性的 和 线性的

stack 栈

Stack称为栈,栈和队列非常相似,只不过队列是先进先出,而栈中的数据添加和移除都在一端进行,遵守栈中的数据则后进先出。Stack类实现了ICollection和IEnumerable接口。

定义如下:

Stack stack = new Stack(); 

Stack stackInt = new Stack();

1.后进先出(LIFO)的一种数据结构。

2.随着向 Stack 中添加元素,容量通过重新分配按需自动增 加。

3.Stack 接受 null 作为有效值并且允许重复的元素。 

  queue队列

Queue称为队列,队列是这样一种数据结构,数据有列表的

一端插入,并由列表的另一端移除。就像单行道,只能从一

段进,从一端出。Queue类同样也是实现了ICollection和

IEnumerable接口。

Queue queue = new Queue();

Queue queueString = new Queue();

1.先进先出(FIFO)的一种数据结构。

2.随着向Queue 中添加元素,容量通过重新分配按需自动增加。

可通过调用 TrimToSize 来减少容量。

3.Queue 接受 null 作为有效值并且允许重复的元素。

4.在AI寻路算法中经常用的Queue。

dictionary字典

Dictionary 类称为字典类,表示键和值的集合。其中TKey表示字典中的类型,Tvalue表示字典中的值类型。Dictionary类实现了ICollection、IEnumerable、IDictionary·接口。

定义如下:

Dictionary<string,int> dic = new Dictionary<string,int>();

1.字典是一个泛型集合。

2.TKey必须唯一。

3.Value可以是变量,也可以是对象。

(1) 和哈希表相似之处:

    Dictionary里面的每一个元素都是一个键值对(由二个元素组成:键和值)  键必须是唯一的,而值不需要唯一的.

(2) 和哈希表的不同之处:  

键和值的类型取决于定义字典时的设置类型。通过一个键读取一个值的时间是接近O(1),键值对之间的偏序可以不定义

Hashtable 哈希表

 存入数据不限制类型和数量,前提是导入命名空间using system.Collection

(1)存值时:

哈希表以键值对的形式存入数据(每个键对应一个值),存值时不允许重复(key不能重复),

(2)取值时:

键值对的排列具有无序性;

取值时找key(键),value(值)与key对应;

显示数据要用foreach循环,foreach从开始循环到结束,中间不会停下。

ArrayList

ArrayList是一个特殊的数组。通过添加和删除元素,就可以动态改变数组的长度。ArrayList并不是强类型,ArrayList 可能并不总是提供特定任务的最佳性能。ArrayList类实现了IList、ICollection和IEnumerable接口。

定义如下:

ArrayList arraylist = new ArrayList();

1.支持自动改变大小的功能。

2.可以灵活的插入元素、删除元素、访问元素。

3.不是强类型,速度跟数组比起来要慢。

可以插入不同类型的元素

但是每次获取对象都需要进行Object装箱拆箱操作,所以效率不如数组高;

List<T>

List<T>类表示可通过索引访问的对象的强类型列表。 提供用于对列表进行搜索、排序和操作的方法。List<T>是ArrayList类的泛型等效类,该类使用大小可按需动态增加的数组实现IList<T>泛型接口。List<T>类同样也是实现了ICollection、IEnumerable和IList接口。

定义如下:

List<int> list = new List<int>();

1.于ArrayList相比, List<T> 类在大多数情况下执行得更好并且是类型安全的。

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

索引器

索引器允许类或结构的实例就像数组一样进行索引。 索引器类似于属性,不同之处在于它们的取值函数采用参数。 C#中的类成员可以是任意类型,包括数组和集合。当一个类包含了数组和集合成员时,索引器将大大简化对数组或集合成员的存取操作。

[修饰符] 数据类型 this[索引类型 index]

{

get{//获得属性的代码}

set{ //设置属性的代码}

}

1.数据类型是表示将要存取的数组或集合元素的类型。

2.索引器类型表示该索引器使用哪一类型的索引来存取

数组或集合元素,可以是整数,可以是字符串;this表

示操作本对象的数组或集合成员,可以简单把它理解成

索引器的名字,因此索引器不能具有用户定义的名称.

索引器的使用:对象名[索引]

相关文章

  • 我的Swift的学习总结 -->第二周

    集合 集合:Set,定义一个集合可以写成:var 集合名 : Set<集合类型> = [集合元素],具体的集合应用...

  • markdown 测试

    集合 集合 集合 引用

  • kotlin学习第五天:集合,高阶函数,Lambda表达式

    集合 list集合 list集合分为可变集合与不可变集合。由list of创建的集合为不可变集合,不能扩容,不能修...

  • kotlin练习 ---- 集合练习

    kotlin练习 - 集合练习 Set集合 Set集合创建 Set集合的使用 List集合 List集合创建 Li...

  • 集合总结

    集合 集合分为单列集合和双列集合两种: 一.单列集合: Collection是单列集合的顶级接口: 其中有三类集合...

  • 映射、元组、集合

    映射 元组 集合 集合之seq 集合之set 集合之map

  • 16.Collection集合

    主要内容: Collection 集合 迭代器 增强for List 集合 Set 集合 1,集合 集合是java...

  • 集合与有序集合

    集合分为有序集合 (zset) 和无序集合 (set), 一般无序集合也直接说成集合 无序集合 (set) 无序集...

  • python入坑第八天|集合

    好的,各位蛇友,我们今天来学习集合。 内容: 集合的创建 集合操作符号 集合的内置函数 集合的创建 集合用set(...

  • 集合框架

    集合框架的概念 集合:存放数据的容器 集合框架:java中,用于表示集合,以及操作集合的类和接口的统称 数组与集合...

网友评论

      本文标题:集合

      本文链接:https://www.haomeiwen.com/subject/wxoowxtx.html