C++中memset函數用法詳解。本站提示廣大學習愛好者:(C++中memset函數用法詳解)文章只能為提供參考,不一定能成為您想要的結果。以下是C++中memset函數用法詳解正文
本文實例講述了C++中memset函數用法。分享給年夜家供年夜家參考,詳細以下:
功 能: 將s所指向的某一塊內存中的每一個字節的內容全體設置為ch指定的ASCII值,塊的年夜小由第三個參數指定,這個函數平日為新請求的內存做初始化任務
用 法: void memset(void *s, char ch, unsigned n);
法式示例:
#include <string.h> #include <stdio.h> #include <memory.h> int main(void) { char buffer[] = "Hello world\n"; printf("Buffer before memset: %s\n", buffer); memset(buffer, '*', strlen(buffer) ); printf("Buffer after memset: %s\n", buffer); return 0; }
輸入成果:
Buffer before memset: Hello world
Buffer after memset: ***********
編譯平台:
Microsoft Visual C++ 6.0
也紛歧定就是把內容全體設置為ch指定的ASCII值,並且該處的ch可為int或許其他類型,其實不必定如果char類型。例以下面如許:
char array[5] = {1,4,3,5,2}; for(int i = 0; i < 5; i++) cout<<array[i]<<" "; cout<<endl; memset(array,"0",5*sizeof(int)); for(int k = 0; k < 5; k++) cout<<array[k]<<" "; cout<<endl;
輸入的成果就是:
1 4 3 5 2
0 0 0 0 0
前面的表年夜小的參數是以字節為單元,所以,關於int或其他的就其實不是都乘默許的1(字符型)了。並且分歧的機械上int的年夜小也能夠分歧,所以最好用sizeof()。
要留意的是,memset是對字節停止操作,所以上述法式假如改成
int array[5] = {1,4,3,5,2}; for(int i = 0; i < 5; i++) cout<<array[i]<<" "; cout<<endl; memset(array,1,5*sizeof(int));// 留意 這裡與下面的法式分歧 for(int k = 0; k < 5; k++) cout<<array[k]<<" "; cout<<endl;
輸入的成果就是:
1 4 3 5 2
16843009 16843009 16843009 16843009 16843009
為何呢?
由於memset是以字節為單元就是對array指向的內存的5個字節停止賦值,每一個都用ASCII為1的字符去填充,轉為二進制後,1就是00000001,占一個字節。一個INT元素是4字節,合一路就是00000001000000010000000100000001,就等於16843009,就完成了對一個INT元素的賦值了。
所以用memset對非字符型數組賦初值是弗成取的!(????我似乎看到有可以啊,又帶確認)
例若有一個構造體Some x,可以如許清零:
memset( &x, 0, sizeof(Some) );
假如是一個構造體的數組Some x[10],可以如許:
menset( x, 0, sizeof(Some)*10 );
memset函數具體解釋
1. void *memset(void *s,int c,size_t n)
總的感化:將已開拓內存空間 s 的首 n 個字節的值設為值 c。
2. 例子
main(){ char *s="Golden Global View"; clrscr(); memset(s,'G',6);//貌似這裡有點成績// printf("%s",s); getchar(); return 0; }
【這個成績相當年夜,法式基本就運轉不下去了,你這裡的S志向的是一段只讀的內存,而你memset又試圖修正它,所以運轉時要失足,修正方法char *s修正為char s[]】
3. memset() 函數經常使用於內存空間初始化。如:
char str[100]; memset(str,0,100);
4. memset()的深入內在:用來對一段內存空間全體設置為某個字符,普通用在對界說的字符串停止初始化為‘memset(a, '\0', sizeof(a));
memcpy用來做內存拷貝,你可以拿它拷貝任何數據類型的對象,可以指定拷貝的數據長度;例:
char a[100], b[50]; memcpy(b, a, sizeof(b)); //留意如用sizeof(a),會形成b的內存地址溢出。
strcpy就只能拷貝字符串了,它碰到'\0'就停止拷貝;例:
char a[100], b[50]; strcpy(a,b);
如用strcpy(b,a),要留意a中的字符串長度(第一個‘\0'之前)能否跨越50位,如跨越,則會形成b的內存地址溢出。
5. 彌補:或人的一點心得
memset可以便利的清空一個構造類型的變量或數組。
如:
struct sample_struct { char csName[16]; int iSeq; int iType; };
關於變量
struct sample_strcut stTest;
普通情形下,清空stTest的辦法:
stTest.csName[0]='\0'; stTest.iSeq=0; stTest.iType=0;
用memset就異常便利:
memset(&stTest,0,sizeof(struct sample_struct));
假如是數組:
struct sample_struct TEST[10];
則:
memset(TEST,0,sizeof(struct sample_struct)*10);
或:
memset(TEST,0,sizeof(TEST));
願望本文所述對年夜家C++法式設計有所贊助。