文章講解了在WINDOWS下,最好的方式是用Virtual Alloc分配內(nèi)存,它不是在堆,也不是在棧,而是直接在進(jìn)程地址空間保留一塊內(nèi)存,雖然用起來最不方便。但是速度快,也最靈活。
10:a=c[1];
004010678A4DF1movcl,byteptr[ebp-0Fh]
0040106A884DFCmovbyteptr[ebp-4],cl
11:a=p[1];
0040106D8B55ECmovedx,dwordptr[ebp-14h]
004010708A4201moval,byteptr[edx+1]
004010738845FCmovbyteptr[ebp-4],al
第一種在讀取時(shí)直接就把字符串中的元素讀到寄存器cl中,而第二種則要先把指針值讀到edx中,在根據(jù)edx讀取字符,顯然慢了。
2.7小結(jié):
堆和棧的區(qū)別可以用如下的比喻來看出:
使用棧就象我們?nèi)ワ堭^里吃飯,只管點(diǎn)菜(發(fā)出申請)、付錢、和吃(使用),吃飽了就走,不必理會(huì)切菜、洗菜等準(zhǔn)備工作和洗碗、刷鍋等掃尾工作,好處是快捷,但是自由度小。
使用堆就象是自己動(dòng)手做喜歡吃的菜肴,比較麻煩,但是比較符合自己的口味,而且自由度大。
自我總結(jié):
相關(guān)推薦:C++等考輔導(dǎo):C++static關(guān)鍵字使用時(shí)的技巧
2009年C++等考輔導(dǎo):類靜態(tài)成員和靜態(tài)成員函數(shù)