日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

ArrayList遍历

發(fā)布時間:2024/6/14 编程问答 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 ArrayList遍历 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

遍歷ArrayList:

????????ArrayList?tableHead?=?new?ArrayList();
????????tableHead?=?ReportsProcess.TableHead(baoBiaoXinXi,?LabelZhuJian.Text.Trim());
????????//?遍歷ArrayList
????????foreach?(object?obj?in?tableHead)
????????{
????????????Response.Write(obj.ToString());
????????}

?

????????///?<summary>
????????///?表頭設(shè)置
????????///?</summary>
????????///?<param?name="baoBiaoXinXi">報表信息表</param>
????????///?<param?name="sn">報表主鍵</param>
????????///?<returns></returns>

????????public?static?ArrayList?TableHead(string?baoBiaoXinXi,?string?sn)
????????{
????????????ArrayList?tableHead?=?new?ArrayList();

????????????String?conn?=?OracleHelper.DatabaseConnStr;
????????????String?queryBiaoTou?=?"SELECT?*?FROM?"?+?baoBiaoXinXi?+?"?WHERE?SN='"?+?sn+?"'?";
????????????OracleDataReader?drBiaoTou?=?OracleHelper.ExecuteReader(conn,?CommandType.Text,?queryBiaoTou,?null);
????????????while?(drBiaoTou.Read())
????????????{
????????????????tableHead.Add("<table><tr><td>報表日期:</td><td>"?+?drBiaoTou.GetString(0)?+?"</td></tr>");
????????????????tableHead.Add("<table><tr><td>報表編號:</td><td>"?+?drBiaoTou.GetString(1)?+?"</td></tr></table>");
????????????????tableHead.Add("<table><tr><td>報表名稱:</td><td>"?+?drBiaoTou.GetString(2)?+?"</td></tr></table>");
????????????????tableHead.Add("<table><tr><td>編制單位:</td><td>"?+?drBiaoTou.GetString(3)?+?"</td></tr></table>");
????????????????tableHead.Add("<table><tr><td>企業(yè)負(fù)責(zé)人:</td><td>"?+?drBiaoTou.GetString(4)?+?"</td></tr></table>");
????????????????tableHead.Add("<table><tr><td>統(tǒng)計負(fù)責(zé)人:</td><td>"?+?drBiaoTou.GetString(5)?+?"</td></tr></table>");
????????????????tableHead.Add("<table><tr><td>填表人:</td><td>"?+?drBiaoTou.GetString(6)?+?"</td></tr></table>");
????????????????tableHead.Add("<table><tr><td>聯(lián)系電話:</td><td>"?+?drBiaoTou.GetString(7)?+?"</td></tr></table>");
????????????????tableHead.Add("<table><tr><td>報出日期:</td><td>"?+?drBiaoTou.GetString(8)?+?"</td></tr></table>");
????????????????tableHead.Add("<table><tr><td>主管領(lǐng)導(dǎo):</td><td>"?+?drBiaoTou.GetString(9)?+?"</td></tr></table>");
????????????????tableHead.Add("<table><tr><td>備注:</td><td>"?+?drBiaoTou.GetString(10)?+?"</td></tr></table>");
????????????????tableHead.Add("<table><tr><td>錄入人:</td><td>"?+?drBiaoTou.GetString(11)?+?"</td></tr></table>");

????????????????tableHead.Add("<br>");
????????????}

????????????drBiaoTou.Close();

????????????return?tableHead;
????????}

1、ArrayList定義

System.Collections.ArrayList類是一個特殊的數(shù)組(即動態(tài)數(shù)組)。

通過添加和刪除元素,就可以動態(tài)改變數(shù)組的長度。

2.優(yōu)點(diǎn)

動態(tài)的增加和刪除元素

實(shí)現(xiàn)了ICollection和IList接口

靈活的設(shè)置數(shù)組的大小

3.ArrayList的構(gòu)造器

構(gòu)造器函數(shù)

注釋

public?ArrayList();

默認(rèn)的構(gòu)造器,將會以默認(rèn)(16)的大小來初始化內(nèi)部的數(shù)組

public?ArrayList(ICollection);

用一個實(shí)現(xiàn)了ICollection接口的對象來構(gòu)造,并將該集合的元素添加到ArrayList

public?ArrayList(int);

用指定的大小來初始化內(nèi)部的數(shù)組

4、ArrayList的屬性

屬性名

注釋

Count

目前ArrayList包含的元素的數(shù)量,這個屬性是只讀的。

Capacity

目前ArrayList能夠包含的最大數(shù)量,可以手動的設(shè)置這個屬性,但是當(dāng)設(shè)置為小于Count值的時候會引發(fā)一個異常。

說明:Capacity是ArrayList可以存儲的元素數(shù)。Count是ArrayList中實(shí)際包含的元素數(shù)。Capacity總是大于或等于Count。如果在添加元素時,Count超過Capacity,則該列表的容量會自動加倍擴(kuò)充。
如果Capacity的值顯式設(shè)置,則內(nèi)部數(shù)組也需要重新分配以容納指定的容量。如果Capacity被顯式設(shè)置為0,則公共語言運(yùn)行庫將其設(shè)置為默認(rèn)容量。默認(rèn)容量為16。
在調(diào)用Clear后,Count為0,而此時Capacity確是默認(rèn)容量16,而不是0

5.ArrayList的方法

方法名

注釋

Int Add(object value);

用于添加一個元素到當(dāng)前列表的末尾

?

用于添加一批元素到當(dāng)前列表的末尾

Void Remove(object obj);

用于刪除一個元素,通過元素本身的引用來刪除

Void RemoveAt(int index);

用于刪除一個元素,通過索引值來刪除

Void RemoveRange(int index,int count);

用于刪除一批元素,通過指定開始的索引和刪除的數(shù)量來刪除

Void Insert(int index,object value)

用于添加一個元素到指定位置,列表后面的元素依次往后移動

Void InsertRange(int index,Icollection collec)

用于從指定位置開始添加一批元素,列表后面的元素依次往后移動

Void Sort()

對ArrayList或它的一部分中的元素進(jìn)行排序。

Void Reverse();

將ArrayList或它的一部分中元素的順序反轉(zhuǎn)。

Int IndexOf(object)

Int IndexOf(object,int)

Int IndexOf(object,int,int)

返回ArrayList或它的一部分中某個值的第一個匹配項的從零開始的索引。沒找到返回-1。

Int LastIndexOf(object)

Int LastIndexOf (object,int)

Int LastIndexOf (object,int,int)

返回ArrayList或它的一部分中某個值的最后一個匹配項的從零開始的索引。沒找到返回-1。

?

Bool Contains(object)

確定某個元素是否在ArrayList中。包含返回true,否則返回false

Void TrimSize()

?這個方法用于將ArrayList固定到實(shí)際元素的大小,當(dāng)動態(tài)數(shù)組元素確定不在添加的時候,可以調(diào)用這個方法來釋放空余的內(nèi)存。

Void Clear();

清空ArrayList中的所有元素

Array ToArray()

這個方法把ArrayList的元素Copy到一個新的數(shù)組中。

?

6、ArrayList的使用注意事項

1、IsSynchronized屬性和ArrayList.Synchronized方法
????IsSynchronized屬性指示當(dāng)前的ArrayList實(shí)例是否支持線程同步,而ArrayList.Synchronized靜態(tài)方法則會返回一個ArrayList的線程同步的封裝。
????如果使用非線程同步的實(shí)例,那么在多線程訪問的時候,需要自己手動調(diào)用lock來保持線程同步,例如:
ArrayList?list?=?new?ArrayList();
lock(?list.SyncRoot?)?//當(dāng)ArrayList為非線程包裝的時候,SyncRoot屬性其實(shí)就是它自己,但是為了滿足ICollection的SyncRoot定義,這里還是使用SyncRoot來保持源代碼的規(guī)范性
{
list.Add(?“Add?a?Item”?);
}

?????如果使用ArrayList.Synchronized方法返回的實(shí)例,那么就不用考慮線程同步的問題,這個實(shí)例本身就是線程安全的,實(shí)際上ArrayList內(nèi)部實(shí)現(xiàn)了一個保證線程同步的內(nèi)部類,ArrayList.Synchronized返回的就是這個類的實(shí)例,它里面的每個屬性都是用了

lock關(guān)鍵字來保證線程同步。

但是,使用這個方法(ArrayList.Synchronized)并不能保證枚舉的同步,例如,一個線程正在刪除或添加集合項,而另一個線程同時進(jìn)行枚舉,這時枚舉將會拋出異常。所以,在枚舉的時候,你必須明確使用 SyncRoot 鎖定這個集合。

Hashtable與ArrayList關(guān)于線程安全性的使用方法類似。

?

2、ArrayList是Array的復(fù)雜版本
ArrayList內(nèi)部封裝了一個Object類型的數(shù)組,從一般的意義來說,它和數(shù)組沒有本質(zhì)的差別,甚至于ArrayList的許多方法,如Index、IndexOf、Contains、Sort等都是在內(nèi)部數(shù)組的基礎(chǔ)上直接調(diào)用Array的對應(yīng)方法。
3、內(nèi)部的Object類型的影響
?????????對于一般的引用類型來說,這部分的影響不是很大,但是對于值類型來說,往ArrayList里面添加和修改元素,都會引起裝箱和拆箱的操作,頻繁的操作可能會影響一部分效率。
4、數(shù)組擴(kuò)容
這是對ArrayList效率影響比較大的一個因素。
每當(dāng)執(zhí)行Add、AddRange、Insert、InsertRange等添加元素的方法,都會檢查內(nèi)部數(shù)組的容量是否不夠了,如果是,它就會以當(dāng)前容量的兩倍來重新構(gòu)建一個數(shù)組,將舊元素

Copy到新數(shù)組中,然后丟棄舊數(shù)組,在這個臨界點(diǎn)的擴(kuò)容操作,應(yīng)該來說是比較影響效率的。
?????例1:比如,一個可能有200個元素的數(shù)據(jù)動態(tài)添加到一個以默認(rèn)16個元素大小創(chuàng)建的ArrayList中,將會經(jīng)過:
16*2*2*2*2?=?256
四次的擴(kuò)容才會滿足最終的要求,那么如果一開始就以:
ArrayList?List?=?new?ArrayList(?210?);
的方式創(chuàng)建ArrayList,不僅會減少4次數(shù)組創(chuàng)建和Copy的操作,還會減少內(nèi)存使用。
?????例2:預(yù)計有30個元素而創(chuàng)建了一個ArrayList:
ArrayList?List?=?new?ArrayList(30);
在執(zhí)行過程中,加入了31個元素,那么數(shù)組會擴(kuò)充到60個元素的大小,而這時候不會有新的元素再增加進(jìn)來,而且有沒有調(diào)用TrimSize方法,那么就有1次擴(kuò)容的操作,并且浪費(fèi)了29個元素大小的空間。如果這時候,用:
ArrayList?List?=?new?ArrayList(40);
那么一切都解決了。
所以說,正確的預(yù)估可能的元素,并且在適當(dāng)?shù)臅r候調(diào)用TrimSize方法是提高ArrayList使用效率的重要途徑。
5、頻繁的調(diào)用IndexOf、Contains等方法(Sort、BinarySearch等方法經(jīng)過優(yōu)化,不在此列)引起的效率損失
首先,我們要明確一點(diǎn),ArrayList是動態(tài)數(shù)組,它不包括通過Key或者Value快速訪問的算法,所以實(shí)際上調(diào)用IndexOf、Contains等方法是執(zhí)行的簡單的循環(huán)來查找元素,所以頻繁的調(diào)用此類方法并不比你自己寫循環(huán)并且稍作優(yōu)化來的快,如果有這方面的要求,建議使用Hashtable或SortedList等鍵值對的集合。
ArrayList?al=new?ArrayList();

al.Add("How");
al.Add("are");
al.Add("you!");

al.Add(100);
al.Add(200);
al.Add(300);

al.Add(1.2);
al.Add(22.8);

.........

//第一種遍歷?ArrayList?對象的方法
foreach(object?o?in?al)
{
Console.Write(o.ToString()+"?");
}

//第二種遍歷?ArrayList?對象的方法
IEnumerator?ie=al.GetEnumerator();
while(ie.MoveNext())
{
Console.Write(ie.Curret.ToString()+"?");
}

//第三種遍歷?ArrayList?對象的方法

利用?ArrayList對象的Count屬性,它返回一此對象中的元素個數(shù).
然后在索引?
for(int?i=0;i<Count;i++)
{
Console.Write(al[i].ToString()+"?");
}

轉(zhuǎn)載于:https://www.cnblogs.com/weihengblogs/archive/2013/03/12/2955594.html

總結(jié)

以上是生活随笔為你收集整理的ArrayList遍历的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。