本篇內容介紹了“C#數組初始化的應用方法”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
C#數組初始化的應用在數據壓縮方面的應用是什么呢?我們經常用到數組。每到一定時候就需要對數組全部元素進行清零。由于C#不提供memset()方法。那么讓我們嘗試以下的測試。
C#數組初始化主要程序部份:
static void Main(string[] args) { int i,k; double p = 0; DateTime s, e; byte[] test = new byte[65536]; byte[] test2 = new byte[65536]; for(int i = 0; i < 10; i++) { s = DateTime.Now; for(j=0; j<50000; j++) { //***************// } e = DateTime.Now; TimeSpan c = e - s; Console.WriteLine(c.TotalMilliseconds.ToString()); p += c.TotalMilliseconds; } p /= 10; Console.WriteLine("***" + p.ToString() + "***"); Console.Read(); }
將其中注釋部份替換成以下幾種方法:
1.test = new byte[65536];
這種方法顯而易懂,每次都新建數組,里面的數值當然都是0啦。
2.memset(test,0,65536);
仿照C++自寫一個memset函數:
public static void memset(byte[] buf, byte val, int size) { int i; for(i=0; i < size; i++) buf[i] = val; }
3.for(k = 0; k < 65536; test[k++] = 0);
把函數memset直接寫入注釋部份。這樣的想法很簡單,節省調用函數的開銷。
4.Array.Clear(test,0,65536);
直接使用.Net自帶方法。
5.test2.CopyTo(test, 0);
用空數組向目標數組中復制內容。
然后理行測試,結果如下:
方法最長最短平均
方法1:最長1937.5最短1812.5平均1842.1875
方法2:最長4593.75最短4625平均4584.375
方法3:最長6046.875最短5984.375平均6001.5625
方法4:最長562.5最短640.5平均581.25
方法5:最長812.5最短750平均770.3125
計算機:P43.0E(超線程開啟)/DDR400 512M(雙通道)軟件環境:Win XP - Sp2/VS2003單位:毫秒(ms)
結果很顯然,Array.Clear()方法是最終的優勝者。但它有一個缺點,就是只可以將數組清空(零)。如果要把數組設置為某一特定格式CopyTo()以空間換時間的方式是***的。
只有一點看不明白,把第2種函數調用改成第3種內嵌式算法后,效率反而下降了。這只能解釋為編譯器的優化了??磥碛肅#寫程序不用太關心函數調用的開銷。
“C#數組初始化的應用方法”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。