C/C++中memset函数
本文学习参考http://baike.baidu.com/link?url=ZmSyY8ciB_nJt9KM-W2fiEFJrC2mugFsLqRdY2b4pLe8rD_jRXyN7_pj0GBBD2bKyt6Xm-lpUlAO97H94dUYXa
1.memset函数的声明和含义如下:
函数解释:将s所指向的某一块内存中的前n个字节的内容全部设置为 ch 指定的 ASCII值, 第一个值为指定的内存地址,块的大小由第三个参数指定,这个函数通常为新申请的内存做初始化工作, 其返回值为指向s的指针。该函数对数组而言只能用于数组的置0或-1,其他值无效。其作用是在一段内存块中填充某个给定的值,它是对较大的结构体或者数组进行清零操作的一种最快方法。函数声明如下:
void * memset(void *s, int ch, size_t n);
memset 函数而已用于初始化内存,例如:
char str[100]; memset(str,0,100);
2.memset函数的常见错误用法
(1)memset函数对数组而言,只能进行置0或者置(-1)操作,而不能是其他的数值。
因为memset函数是对单个字节进行操作,如果将int a[5]值为2,操作为:memset(a,2,sizeof(int)*5);因为他是整型数组,有四个字节,而每个字节都被赋值为2,即a[5]中的每个元素的每个字节都被赋值为2(例如a[0]的二进制表示为00000010 00000010 00000010 00000010 , 所以输出十进制a[0]的值为 33686018);而(-1)的二进制表示为(11111111 11111111 11111111 11111111),因此置为(-1)不会改变其值。
(2)memset(void *s, int key,size_t n) 中ch实际范围应该在0~~255。
(3)注意ch 和 n 的位置不能弄反
3.memset的使用情形比较
例如:将 char a[20] 进行清零的操作如下
memset(a,0,20*sizeof(char)); //将char a[20] 清零
(1)两种情况下使用memset函数的比较
char buffer[4]; memset(buffer,0,sizeof(char)*4); //将buffer[4] 清零 strcpy(buffer,"123"); //将字符串 “123” 复制到 buffer中 //此时字符串的总长为4位(包括结尾的 ‘\0’ ) //因为拷贝的字符串将buffer全部覆盖,因此,此时的memset可以不需要
char buffer[20]; memset(buffer,0,sizeof(char)*20); memcpy(buffer,"123",3); //这一条的memset并不多余,memcpy并没把buffer全部覆盖,如果没有memset, //用printf打印buffer会有乱码甚至会出现段错误。 //如果此处是strcpy(buffer,"123");便不用memset, //strcpy虽然不会覆盖buffer但是会拷贝字符串结束符
(2)Demo如下:
#include <iostream> using namespace std; int main(void) { char buffer[] = "Helloworld\n"; cout << "Buffer before memset: " << buffer << endl; memset(buffer, '*', strlen(buffer)); cout << "Buffer after memset: " << buffer << endl; system("pause"); return 0; }
result:
PS:关于内存访问冲突问题
#include <iostream> using namespace std; int main() { char *s="GoldenGlobalView"; //改为char s[] = "GoldenGlobalView";则没有问题 memset(s,'G',6); //单步运行到这里会提示内存访问冲突 printf("%s",s); getchar(); return 0; }