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];
這種方法顯而易懂,每次都新建數(shù)組,里面的數(shù)值當(dāng)然都是0啦。
2.memset(test,0,65536);
仿照c++自寫一個memset函數(shù): 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); 把函數(shù)memset直接寫入紅色部份。這樣的想法很簡單,節(jié)省調(diào)用函數(shù)的開銷。
4.array.clear(test,0,65536);
直接使用.net自帶方法。
5.test2.copyto(test, 0);
用空數(shù)組向目標(biāo)數(shù)組中復(fù)制內(nèi)容。
然后理行測試,結(jié)果如下:
方法 最長 最短 平均
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
計算機(jī):p43.0e(超線程開啟)/ddr400 512m(雙通道) 軟件環(huán)境:win xp - sp2/vs2003 單位:毫秒(ms)