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);

原创粉丝点击