容器使用笔记(List篇)
上一篇博客介绍了Dictionary,这篇博客介绍List的相关内容。
C#中要存储一组数据。我们会想到数组Array,ArrayList,List这三个对象,当中,数组是最早出现的,我们就从数组開始吧。
数组有非常多长处,数组的使用比較简单,而且数组在内存中是连续存储的。所以数据存取速度比較快。
定义一个数组Array:
//定义、赋值
<span style="font-size:18px;"> int[] intTest = new int[3];
intTest[0] = 1;
intTest[1] = 2;
intTest[2] = 3; //改动
intTest[1] = 5;</span>
可是,数组有非常多缺陷,比方说,它的长度就是个大坑,我们在定义数组的时候必须指定数组长度,假设长度过长则浪费内存。假设过短。会编译错误,出现溢出现象,假如我们事先不知道数组的长度,那使用起来简直是坑爹。
而且,数据不能删除数据,要插入一条数据。也是相当的困难。
针对数组的这些问题。C#推出了ArrayList。能够说,ArrayList完美的攻克了数组的种种缺陷。
ArrayList是System.Collections;命名空间下的集合类,我们在定义ArrayList时,不须要去指定它的长度,它的长度能够在执行时动态改变来满足实际须要。
ArrayList继承了IList接口。能够方便的进行数据加入、改动、插入、删除操作。代码例如以下:
<span style="white-space:pre"> </span> //定义、加入数据
ArrayList arrayList = new ArrayList();
arrayList.Add(1);
arrayList.Add(2);
arrayList.Add(3);
//改动
arrayList[0] = "5";
//删除
arrayList.RemoveAt(0);
//插入数据
arrayList.Insert(0, 555);
ArrayList的存储结构是跟数组的存储结构同样,也是连续存储,所以数据查询和加入速度比較快,可是删除速度比較慢,由于连续存储的数据改变了当中的一个记录,就须要改变整个数组的索引,这个是比較麻烦的。
ArrayList能够说非常好的攻克了数组的缺陷,可是它也不是完美的。大家细致观察上边的代码,会发现,我们给实例arrayList对象的第一个索引值是int类型的1,可是改动数据时,我们改成了string类型的5,也就是说。arrayList
这个对象中,既有int类型数据。也包含string类型数据。那我们在使用的时候,岂不是每次都要去推断呢?假如,我们又多加入了几种类型呢?程序肯定会报错。
假如说。我们就是在程序中做了无数的推断,但是系统中装箱、拆箱的操作也能把人折磨死,而且,对内存是一种极大的消耗。
C#2.0泛型的出现。非常好的攻克了这个问题。ArrayList的类型安全为程序带来了极大的隐患,List要求在定义的时候必须给出明白的数据类型,所以,List是强类型的集合,而且,泛型的出现。避免了数据交换和存储时装箱和拆箱的操作,极大的降低了内存的损耗。它的使用方法和arrayList基本同样。代码例如以下:
<span style="white-space:pre"> </span> //定义、加入数据
List<string> listTest = new List<string>();
listTest.Add("a");
listTest.Add("b");
listTest.Add("c");
//改动
listTest[1] = "abc";
//移除
listTest.RemoveAt(0);
//插入数据
listTest.Insert(0, "Hello World!");
总结:
数组:数组能够多维度的存储数据。在内存中已顺序表结构存储,通过索引下表来查找数据,查询效率高。数据操作方便。可是,长度固定,数据插入困难,假设须要以多维数据结构存储时推荐使用。
ArrayList:数组的强化版本号。长度可变化,内存中已顺序表结构存储,通过索引查找数据,查询效率高,继承了IList接口,数据操作简单。类型不安全。数据查询和存储时须要经过装箱和拆箱操作,内存浪费较大,不建议使用。
List:ArrayList的泛型版本号。强类型数据集合,数据操作简单,内存中已链式存储结构存在,能够通过索引查询数据,查询效率较高,操作一般集合时建议使用。
容器使用笔记(List篇)的更多相关文章
- 《javascript权威指南》读书笔记——第二篇
<javascript权威指南>读书笔记——第二篇 金刚 javascript js javascript权威指南 今天是今年的196天,分享今天的读书笔记. 第2章 词法结构 2.1 字 ...
- 《javascript权威指南》读书笔记——第一篇
<javascript权威指南>读书笔记——第一篇 金刚 javascript js javascript权威指南 由于最近想系统学习下javascript,所以开始在kindle上看这本 ...
- IOC容器特性注入第一篇:程序集反射查找
学习kooboo的框架发现它的注入容器方法比较特别,同样是利用MVC的注入点,但它是查找网站下面bin所有的DLL利用反射查找特性找到对应的服务注入到容器. 这样的好处很简单:完全可以不用关心IOC容 ...
- PHP学习笔记 - 进阶篇(11)
PHP学习笔记 - 进阶篇(11) 数据库操作 PHP支持哪些数据库 PHP通过安装相应的扩展来实现数据库操作,现代应用程序的设计离不开数据库的应用,当前主流的数据库有MsSQL,MySQL,Syba ...
- PHP学习笔记 - 进阶篇(10)
PHP学习笔记 - 进阶篇(10) 异常处理 抛出一个异常 从PHP5开始,PHP支持异常处理,异常处理是面向对象一个重要特性,PHP代码中的异常通过throw抛出,异常抛出之后,后面的代码将不会再被 ...
- PHP学习笔记 - 进阶篇(9)
PHP学习笔记 - 进阶篇(9) 图形图像操作 GD库简介 GD指的是Graphic Device,PHP的GD库是用来处理图形的扩展库,通过GD库提供的一系列API,可以对图像进行处理或者直接生成新 ...
- PHP学习笔记 - 进阶篇(8)
PHP学习笔记 - 进阶篇(8) 日期与时间 取得当前的Unix时间戳 UNIX 时间戳(英文叫做:timestamp)是 PHP 中关于时间与日期的一个很重要的概念,它表示从 1970年1月1日 0 ...
- PHP学习笔记 - 进阶篇(7)
PHP学习笔记 - 进阶篇(7) 文件操作 读取文件内容 PHP具有丰富的文件操作函数,最简单的读取文件的函数为file_get_contents,可以将整个文件全部读取到一个字符串中. $conte ...
- PHP学习笔记 - 进阶篇(6)
PHP学习笔记- 进阶篇(6) 会话控制(session与cookie) 当前的Cookie为: cookie简介 Cookie是存储在客户端浏览器中的数据,我们通过Cookie来跟踪与存储用户数据. ...
- PHP学习笔记 - 进阶篇(4)
PHP学习笔记 - 进阶篇(4) 字符串操作 字符串介绍 PHP开发中,我们遇到最多的可能就是字符串. 字符串变量用于包含字符串的值. 一个字符串 通过下面的3种方法来定义: 1.单引号 2.双引号 ...
随机推荐
- Windows虚拟桌面
PROCESS_INFORMATION ProcessInfo; STARTUPINFO StartupInfo; HDESK hDesktop; HDESK hOriginalThread; HDE ...
- C++ new delete(二)
C++基础遗漏:new和delete 我记得当年学习C++基础的时候,老师曾经告诉我们:一般来说new和delete要成对出现,在使用完new申请的内存后要马上释放.我相信持这种说法的人不止我们老师一 ...
- 2011 luogu P1311 选择客栈
题目描述 丽江河边有 nn 家很有特色的客栈,客栈按照其位置顺序从 1 到 n 编号.每家客栈都按照某一种色调进行装饰(总共 k 种,用整数 0 ~ k-1 表示),且每家客栈都设有一家咖啡店,每家咖 ...
- 条款28:避免返回handles指向对象内部的成分(Avoid returning "handles" to objects internals)
NOTE: 1.避免返回handles(包括references 指针 迭代器)指向对象内部.遵守这个条款可增加分装性,帮助const 成员函数的行为像个const,并将发生“虚吊号码牌”(dangl ...
- vue 页面过渡效果
App.vue 模板 <template> <div id="app"> <transition :name="transition&quo ...
- vim的操作命令
vim常用命令 在命令状态下对当前行用== (连按=两次), 或对多行用n==(n是自然数)表示自动缩进从当前行起的下面n行.你可以试试把代码缩进任意打乱再用n==排版,相当于一般IDE里的code ...
- C语言 NULL 是什么鬼
NULL , 0 , '\0' 之间的区别与联系 1.NULL 结构体的使用中,都可以用NULL表示空,那么NULL是什么 #ifndef __cplusplus #define NULL ((vo ...
- PS日记一
shift+alt 从中心开始画圆 PHOTOSHOP是处理位图的软件, 栅格化是将矢量图形如:(Illustrator,或者CoreIDRAW中绘画的图形), 包括文字,这些矢量图文转换(也叫栅格化 ...
- NGINX模块(二)
[Nginx标准HTTP模块] 一.HTTP核心模块 指令1:alias 语法:alias file-path|directory-path; 默认值:no 使用字段:location 说明:这个指令 ...
- xtu read problem training B - Tour
B - Tour Time Limit:1000MS Memory Limit:65536KB 64bit IO Format:%I64d & %I64u Descriptio ...