網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
在"C#中List<T>是怎么存放元素的"中,分析了List<T>的源碼,了解了List<T>是如何存放元素的。這次,就自定義一個(gè)泛型集合類型,可實(shí)現(xiàn)添加元素,并支持遍歷
該泛型集合類型一定需要一個(gè)添加元素的方法,在添加元素的時(shí)候需要考慮:當(dāng)添加的元素超過(guò)當(dāng)前數(shù)組的容量,就讓數(shù)組擴(kuò)容;為了支持循環(huán)遍歷,該泛型集合類型必須提供一個(gè)迭代器(實(shí)現(xiàn)IEnumerator接口)。
public class MyList<T>
{
T[] items = new T[5];
private int count;
public void Add(T item)
{
if(count == items.Length)
Array.Resize(ref items, items.Length * 2);
items[count++] = item;
}
public IEnumerator<T> GetEnumerator()
{
return new MyEnumeraor(this);
}
class MyEnumeraor : IEnumerator<T>
{
private int index = -1;
private MyList<T> _myList;
public MyEnumeraor(MyList<T> myList)
{
_myList = myList;
}
public T Current
{
get
{
if (index < 0 || index >= _myList.count)
{
return default(T);
}
return _myList.items[index];
}
}
public void Dispose()
{
}
object System.Collections.IEnumerator.Current
{
get { return Current; }
}
public bool MoveNext()
{
return ++index < _myList.count;
}
public void Reset()
{
index = -1;
}
}
}
- 泛型集合類型維護(hù)著一個(gè)T類型的泛型數(shù)組
- 私有字段count是用來(lái)計(jì)數(shù)的,每添加一個(gè)元素計(jì)數(shù)加1
- 添加方法考慮了當(dāng)count計(jì)數(shù)等于當(dāng)前元素的長(zhǎng)度,就讓數(shù)組擴(kuò)容為當(dāng)前的2倍
- 迭代器實(shí)現(xiàn)了IEnumerator<T>接口
客戶端調(diào)用。
class Program
{
static void Main(string[] args)
{
MyList<int> list = new MyList<int>();
list.Add(1);
list.Add(2);
foreach (int item in list)
{
Console.WriteLine(item);
}
Console.ReadKey();
}
}
另外,IEnumerable和IEnumerator的區(qū)別是什么呢?
其實(shí),真正執(zhí)行迭代的是IEnumerator迭代器。IEnumerable接口就提供了一個(gè)方法,就是返回IEnumerator迭代器。
public interface IEnumerable
{
IEnumerator GetEnumerator();
}
原文鏈接:https://www.cnblogs.com/darrenji/p/3978354.html
相關(guān)推薦
- 2022-11-05 ios開發(fā)?try-catch引起的野指針問(wèn)題排查_IOS
- 2022-06-28 詳解Python中遞歸函數(shù)的原理與使用_python
- 2022-05-21 Python內(nèi)置數(shù)據(jù)類型中的集合詳解_python
- 2023-07-22 垃圾回收的核心知識(shí)點(diǎn)解析
- 2022-09-17 Python?seaborn數(shù)據(jù)可視化繪圖(直方圖,密度圖,散點(diǎn)圖)_python
- 2022-06-25 Python+matplotlib繪制條形圖和直方圖_python
- 2022-05-22 C#編程之依賴倒置原則DIP_C#教程
- 2022-12-25 C++?Boost?Random隨機(jī)函數(shù)詳解_C 語(yǔ)言
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過(guò)濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支