基于memset()函數(shù)的深入理解
更新時間:2013年05月31日 16:58:12 作者:
本篇文章是對memset()函數(shù)又進(jìn)行了深一步的了解,需要的朋友參考下
今天寫軟件工程大作業(yè),調(diào)了半天的bug,原來是對memset函數(shù)認(rèn)識不到位造成的。
int max[teachRelationNum];
memset(max,0,sizeof(max));
注意啊,可以使用sizeof(max),也可以使用 sizeof(int)*teachRelationNum,不可以直接使用 teachRelationNum,來初始化!
一般情況下,可以這樣使用:
memset(max,0,sizeof(max));
memset(max,-1,sizeof(max));
memset(max,'a',sizeof(max));
而不能夠賦初值為100之類的,要想賦初值為100,只能通過for循環(huán)了。
具體使用策略:
包含<string.h>
char buffer[] = "Hello world\n";
printf("Buffer before memset: %s\n", buffer);
memset(buffer, '*', strlen(buffer) );
printf("Buffer after memset: %s\n", buffer);
輸出結(jié)果:
Buffer before memset: Hello world
Buffer after memset: ************
int array[5] = {1,4,3,5,2};
memset(array,0,5*sizeof(int));
輸出結(jié)果:0 0 0 0 0
memset(array,1,5*sizeof(int));// 注意 這里與上面的程序不同
輸出結(jié)果:16843009 16843009 16843009 16843009 16843009
因為memset是以字節(jié)為單位就是對array指向的內(nèi)存的4個字節(jié)進(jìn)行賦值,每個都用ASCII為1的字符去填充,轉(zhuǎn)為二進(jìn)制后,1就是00000001,占一個字節(jié)。一個INT元素是4字節(jié),合一起就是00000001000000010000000100000001,就等于16843009,就完成了對一個INT元素的賦值了。
所以用memset對非字符型數(shù)組賦初值是不可取的!
例如有一個結(jié)構(gòu)體Some x,可以這樣清零:
memset( &x, 0, sizeof(Some) );
如果是一個結(jié)構(gòu)體的數(shù)組Some x[10],可以這樣:
memset( x, 0, sizeof(Some)*10 );
以上為對memset()的深刻研究,一部分是自己心得,一部分摘自百度百科。
int max[teachRelationNum];
memset(max,0,sizeof(max));
注意啊,可以使用sizeof(max),也可以使用 sizeof(int)*teachRelationNum,不可以直接使用 teachRelationNum,來初始化!
一般情況下,可以這樣使用:
memset(max,0,sizeof(max));
memset(max,-1,sizeof(max));
memset(max,'a',sizeof(max));
而不能夠賦初值為100之類的,要想賦初值為100,只能通過for循環(huán)了。
具體使用策略:
包含<string.h>
char buffer[] = "Hello world\n";
printf("Buffer before memset: %s\n", buffer);
memset(buffer, '*', strlen(buffer) );
printf("Buffer after memset: %s\n", buffer);
輸出結(jié)果:
Buffer before memset: Hello world
Buffer after memset: ************
int array[5] = {1,4,3,5,2};
memset(array,0,5*sizeof(int));
輸出結(jié)果:0 0 0 0 0
memset(array,1,5*sizeof(int));// 注意 這里與上面的程序不同
輸出結(jié)果:16843009 16843009 16843009 16843009 16843009
因為memset是以字節(jié)為單位就是對array指向的內(nèi)存的4個字節(jié)進(jìn)行賦值,每個都用ASCII為1的字符去填充,轉(zhuǎn)為二進(jìn)制后,1就是00000001,占一個字節(jié)。一個INT元素是4字節(jié),合一起就是00000001000000010000000100000001,就等于16843009,就完成了對一個INT元素的賦值了。
所以用memset對非字符型數(shù)組賦初值是不可取的!
例如有一個結(jié)構(gòu)體Some x,可以這樣清零:
memset( &x, 0, sizeof(Some) );
如果是一個結(jié)構(gòu)體的數(shù)組Some x[10],可以這樣:
memset( x, 0, sizeof(Some)*10 );
以上為對memset()的深刻研究,一部分是自己心得,一部分摘自百度百科。
相關(guān)文章
解析C++中的for循環(huán)以及基于范圍的for語句使用
這篇文章主要介紹了解析C++中的for循環(huán)以及基于范圍的for語句使用,是C++入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下2016-01-01C語言中結(jié)構(gòu)體、聯(lián)合體的成員內(nèi)存對齊情況
這篇文章主要給大家介紹了關(guān)于C語言中結(jié)構(gòu)體、聯(lián)合體的成員內(nèi)存對齊情況的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05C++中的多態(tài)問題—理解虛函數(shù)表及多態(tài)實現(xiàn)原理
這篇文章主要介紹了C++中的多態(tài)問題—理解虛函數(shù)表及多態(tài)實現(xiàn)原理,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-02-02