脚本入门 集合之迭代器
来源:互联网 发布:南京seo 页面优化 编辑:程序博客网 时间:2024/06/05 14:45
欢迎来到U3D社区:
迭代器 概念:
迭代器(iterator)是一种对象,它能够用来遍历标准模板库容器中的部分或全部元素,每个迭代器对象代表容器中的确定的地址。迭代器修改了常规指针的接口,所谓迭代器是一种概念上的抽象:那些行为上像迭代器的东西都可以叫做迭代器。然而迭代器有很多不同的能力,它可以把抽象容器和通用算法有机的统一起来。
迭代器提供一些基本操作符:*、++、==、!=、=。这些操作和C/C++“操作array元素”时的指针接口一致。不同之处在于,迭代器是个所谓的复杂的指针,具有遍历复杂数据结构的能力。其下层运行机制取决于其所遍历的数据结构。因此,每一种容器型别都必须提供自己的迭代器。事实上每一种容器都将其迭代器以嵌套的方式定义于内部。因此各种迭代器的接口相同,型号却不同。这直接导出了泛型程序设计的概念:所有操作行为都使用相同接口,虽然它们的型别不同。
功能:
迭代器使开发人员能够在类或结构中支持foreach迭代,而不必整个实现IEnumerable或者IEnumerator接口。只需提供一个迭代器,即可遍历类中的数据结构。当编译器检测到迭代器时,将自动生成IEnumerable接口或者IEnumerator接口的Current,MoveNext和Dispose方法。
特点;
1.迭代器是可以返回相同类型值的有序序列的一段代码;
2.迭代器可用作方法、运算符或get访问器的代码体;
3.迭代器代码使用yieldreturn语句依次返回每个元素,yield break将终止迭代;
4.可以在类中实现多个迭代器,每个迭代器都必须像任何类成员一样有惟一的名称,并且可以在foreach语句中被客户端,代码调用如下所示:foreach(int x in SimpleClass.Iterator2){};
5.迭代器的返回类型必须为IEnumerable和IEnumerator中的任意一种;
6.迭代器是产生值的有序序列的一个语句块,不同于有一个 或多个yield语句存在的常规语句块;
7.迭代器不是一种成员,它只是实现函数成员的方式,理解这一点是很重要的,一个通过迭代器实现的成员,可以被其他可能或不可能通过迭代器实现的成员覆盖和重载;
8.迭代器块在C#语法中不是独特的元素,它们在几个方面受到限制,并且主要作用在函数成员声明的语义上,它们在语法上只是语句块而已;
9.yield关键字用于指定返回的值。到达yieldreturn语句时,会保存当前位置。下次调用迭代器时将从此位置重新开始执行。 迭代器对集合类特别有用,它提供一种简单的方法来迭代不常用的数据结构(如二进制树)。
例如:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
#include<iostream>
usingnamespacestd;
class_iterator
{
private:
char*p;
public:
_iterator(char*str):p(str){}
char*&operator++()
{
p+=1;//跟p++同价;
returnp;
}
};
intmain()
{
char*p="ThisisC++program";
_iteratorit(p);
cout<<"++之前:"<<p<<endl;
char*p1=++it;//把地址向前加了一个char型长度,然后给指针p1
cout<<"++之后:"<<p1<<endl;
return0;
}
更多精彩在http://unity.gopedu.com/forum.php
0 0
- 脚本入门 集合之迭代器
- Scala入门之集合
- shell脚本---之入门
- 脚本入门之shell_script
- python3入门之集合set
- Java 入门 之 集合 Collection
- 12.Python入门之集合
- Powershell之HelloWorld 脚本入门
- linux之 简略脚本入门
- unity3d学习之脚本入门
- Gradle之构建脚本入门
- JavaSE入门学习38:Java集合框架之迭代器
- Redis快速入门之集合类型
- [入门-4] 基础类型之集合
- 12-Oracle入门之集合运算
- Python零基础入门之十集合
- Spring入门之bean属性注入集合
- C#之入门总结_集合_10
- VirtualBox下安装CentOS详细教程(截图版)
- 关于给个既定日期改成星期几的问题?
- 数据库(增删查改)
- 用代码更改IOS上StatusBar的颜色
- CELL-01548:
- 脚本入门 集合之迭代器
- 单向链表移位
- 常用但忽略的anroid知识10-获取屏幕的宽高
- CAS3.5.x(x>1)支持OAuth2 server
- [scala之一]基础
- 黑马程序员--Object-C--05--id、构造方法、类的深入研究、description、SEL
- 两句话写的很好
- Failed to load class “org.slf4j.impl.StaticLoggerBinder”问题解决
- 网络编程之get,post请求,文件上传及下载