Chinaunix首页 | 论坛 | 博客
  • 博客访问: 5493682
  • 博文数量: 922
  • 博客积分: 19333
  • 博客等级: 上将
  • 技术积分: 11226
  • 用 户 组: 普通用户
  • 注册时间: 2007-03-27 14:33
文章分类

全部博文(922)

文章存档

2023年(1)

2020年(2)

2019年(1)

2017年(1)

2016年(3)

2015年(10)

2014年(17)

2013年(49)

2012年(291)

2011年(266)

2010年(95)

2009年(54)

2008年(132)

分类: C/C++

2008-09-17 15:28:12

memset
开放分类: 、、
功 能: 将s所指向的某一块内存中的每个字节的内容全部设置为ch指定的ASCII值,
块的大小由第三个参数指定,这个函数通常为新申请的内存做初始化工作
用 法: void *memset(void *s, char ch, unsigned n);
程序例:
#include
#include
#include
int main(void)
{
  char buffer[] = "Hello world\n";
  printf("Buffer before memset: %s\n", buffer);
  memset(buffer, '*', strlen(buffer) - 1);
  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类型。例如下面这样:
int array[5] = {1,4,3,5,2};
for(int i = 0; i < 5; i++)
cout<<<" ";
cout<memset(array,0,5*sizeof(int));
for(int k = 0; k < 5; k++)
cout<[k]<<" ";
cout<输出的结果就是: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<<<" ";
cout<memset(array,0,5*sizeof(int));
for(int k = 1; k < 5; k++) // 注意 这里与上面的程序不同
cout<[k]<<" ";
cout<输出的结果就是:1 4 3 5 2
16843009 16843009 16843009 16843009 16843009

为什么呢?
因为memset是以字节为单位就是对array指向的内存的5个字节进行赋值,每个都用ASCII为1的字符去填充,转为二进制后,1就是00000001,占一个字节。一个INT元素是4字节,合一起就是1000000010000000100000001,就等于16843009,就完成了对一个INT元素的赋值了。
所以用memset对非字符型数组赋初值是不可取的!

楼上说的很对,只是程序执行结果是0 0 0 0;程序不同的地方不在那里。程序如下:

int array[5] = {1,4,3,5,2};
for(int i = 0; i < 5; i++)
cout<cout<memset(array,1,5*sizeof(int)); //这里才是不同的地方
for(int k = 0; k < 5; k++) //不同不在这里,k=1只是少循环了一次而已
cout<cout<

例如有一个结构体Some x,可以这样清零:
memset( &x, 0, sizeof(Some) );

如果是一个结构体的数组Some x[10],可以这样:
menset( x, 0, sizeof(Some)*10 );

阅读(1024) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~