memset函数
来源:互联网 发布:解析域名怎么解析 编辑:程序博客网 时间:2024/05/21 22:48
#include <string.h> #include <stdio.h> #include <memory.h> memset函数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指定的ASCⅡ值,而且该处的ch可为int或者其他类型,并不一定要是char类型。例如下面这样: int 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指向的内存的4个字节进行赋值,每个都用ASCⅡ为1的字符去填充,转为二进制后,1就是00000001,占一个字节。一个INT元素是4字节,合一起就是00000001000000010000000100000001,就等于16843009,就完成了对一个INT元素的赋值了。 所以用memset对非字符型数组赋初值是不可取的! 例如有一个结构体Some x,可以这样清零: memset(&x,0,sizeof(Some)); 如果是一个结构体的数组Some x[10],可以这样: memset(x,0,sizeof(Some)*10);