自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

.Net Framework容器與STL的詳細(xì)比較

開發(fā) 后端
.Net Framework容器主要是包含在System.Collections里的。我們可以通過(guò)本文介紹的相關(guān)內(nèi)容詳細(xì)解讀其中的重要概念。

.Net Framework開發(fā)環(huán)境為程序員們帶來(lái)了非常大的好處。在這里我們就先來(lái)了解一下.Net Framework容器與STL容器之間的比較。從中更進(jìn)一步的對(duì).Net Framework有一個(gè)深入的了解程度。#t#

在.Net Framework容器和STL中有眾多的容器,為編程帶來(lái)了方便,我們就先對(duì)這兩種框架里的容器做了一個(gè)比較。

在STL中,主要有這么幾種:

Vector Deque List Set/Multiset Map/Multimap Stack Queue Bitset

在.Net Framework容器包含在System.Collections里,主要有這么幾種:

ArrayList BitArray Hashtable SortedList Queue Stack

這些結(jié)構(gòu)中,有幾個(gè)是功能類似的,比如Vector和ArrayList,都是可自動(dòng)調(diào)整容量的數(shù)組。Queue和Stack也是相同的。

.Net Framework容器與STL容器不同的有這么幾點(diǎn):

1、.NET沒(méi)有Set和Map,只有Hashtable,而標(biāo)準(zhǔn)C++里是沒(méi)有Hashtable的,只有在具體實(shí)作中,有所涉及,比如說(shuō)SGI STL里。

2、.NET有SortedList,這是Hashtable和Array的混合體,功能強(qiáng)大,可是實(shí)現(xiàn)Dictionary。

3、STL的Bitset是存儲(chǔ)位(bit)或布爾值且大小固定的數(shù)組,用于管理各種標(biāo)志(flags)。

.Net Framework容器的BitArray僅存儲(chǔ)布爾值。

這兩個(gè)的實(shí)現(xiàn)和使用方式不同,但是主要用途卻是類似的,MSDN上的例子和《標(biāo)準(zhǔn)程序庫(kù)》的例子相當(dāng)雷同。

關(guān)于容器的訪問(wèn)方式

有了容器,就必須去訪問(wèn),才能運(yùn)用。兩者的訪問(wèn)原理類似,都是用一種特殊的對(duì)象去訪問(wèn)。

⑴STL方式:使用迭代器(iterator),迭代器有許多種,每種容器都有自己的迭代器。但是使用迭代器的方式卻是相同的,這使得我們使用容器相當(dāng)方便。
迭代器行為上類似于指針,內(nèi)部封裝了對(duì)不同容器的操作。對(duì)我們隱藏了容器內(nèi)部復(fù)雜的結(jié)構(gòu)。

⑵.NET的方式頗為不同。類庫(kù)中有一個(gè)名為IEnumerable的接口,所有容器類都繼承實(shí)現(xiàn)了這個(gè)接口。它有一個(gè)公共方法:GetEnumerator()。因此所有容器都有這個(gè)方法,它返回可用于循環(huán)訪問(wèn)集合的IEnumerator,這個(gè)IEnumerator類似于STL的迭代器。

使用實(shí)例:

  1. using System;   
  2. using System.Collections;   
  3.  
  4. public class ArrayListTest   
  5. {   
  6. public static void Main()   
  7. {   
  8. ArrayList alist=new ArrayList();   
  9. alist.Add(1);   
  10. alist.Add(2);   
  11. alist.Add(3);   
  12.  
  13. print(alist);   
  14. }   
  15. public static void print
    (IEnumerable myList)   
  16. {   
  17. System.Collections.IEnumerator 
    myEnum=myList.GetEnumerator();   
  18. while(myEnum.MoveNext())   
  19. {   
  20. Console.WriteLine(myEnum.Current);   
  21. }   
  22. }   
  23. }  

綜合起來(lái)看,.Net Framework容器和STL的容器類型相當(dāng)齊全,都涉及了方方面面,只有細(xì)微差別。訪問(wèn)方式從本質(zhì)上說(shuō)也是一致的。

責(zé)任編輯:曹凱 來(lái)源: 博客園
相關(guān)推薦

2009-12-15 11:28:34

.NET Framew

2014-03-10 10:06:40

WebSocket.Net

2010-01-06 18:13:58

.NET Framew

2010-01-06 19:18:22

.NET Framew

2010-01-05 17:39:10

.NET Framew

2010-01-06 13:50:37

.NET Framew

2009-08-18 11:08:24

.Net Framew

2010-01-06 18:59:41

.Net Framew

2010-01-06 19:38:16

.NET Framew

2009-12-14 10:19:23

.NET Framew

2021-12-25 23:25:04

LinuxDocker容器

2010-01-05 11:26:27

.net Framew

2010-01-06 15:29:13

.NET Framew

2010-01-06 11:30:22

.NET Framew

2009-09-07 15:04:07

2010-01-06 17:20:38

.Net Framew

2011-07-13 15:07:48

STLC++

2009-09-18 09:25:06

LINQ Framew

2009-07-28 14:10:14

2011-07-13 14:49:31

STLC++
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)