memset函数的用法:
1.预备知识:
1个int占4个字节,1个字节占8bit(位),1个字节占1个内存;
-1的二进制是1111 1111,而不是1000 0001,因为负数在计算机中是以补码形式存储的。
-1的原码:1000 0001
-1的反码:1111 1110
-1的补码:1111 1111
正数的反码和原码相同,补码和源码也相同;
负数的反码是符号位不变,其余逐位取反,补码是其反码的末位加1;
2.memset(目标起始地址,要赋的值,字节数)以字节为单位初始化内存块
int num[10];
memset(num,0,10*sizeof(int));
3.错误的赋值
memset(num,1,10*sizeof(int));//为1个int的每个字节赋值为1,则最后结果不为1
00000001 00000001 00000001 00000001
memset(void*s, int ch,size_tn);中key实际范围应该在0~~255,因为该函数只能取ch的后八位赋值给你所输入的范围的每个字节,比如int a[5]赋值memset(a,-1,sizeof(int)*5)与memset(a,511,sizeof(int)*5) 所赋值的结果是一样的都为-1;因为-1的二进制码为(1111111111111111 11111111 11111111)而511的二进制码为(00000000 00000000 00000001 11111111)后八位都为(11111111),所以数组中每个字节,如a[0]含四个字节都被赋值为(11111111),其结果为a[0](1111111111111111 11111111 11111111),及a[0]=-1,因此无论ch多大只有后八位二进制有效,而八位二进制[2] 的范围(0~255)YKQ改。而对字符数组操作时则取后八位赋值给字符数组,其八位值作为ASCII[3] 码。
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但是会拷贝字符串结束符
注意:
在给char以外的数组赋值时,只初始化为0或-1