2015.12.24
printf %u unsigned int
'\0' ascii码 是0 , ‘0’ ascii 码是48
所以如果char* 初始化初始化全0即可,相当于全是'\0'
---------------------
数组初始化:
char str[100];
memset(str,0,100);
int s[] = {1,2,3,4,5};
memset(s, 1, sizeof(s)); // sizeof(s)是5*4=20
推荐使用memset代替bzero
关于memset注意事项。
http://www.cnblogs.com/chenyg32/p/3289068.html
摘要:
1、静态数组作为参数传入某个函数的时候,就会退化成指针,也就是该数组的首地址,其数组的长度信息就丢掉了,这就是在这个语境下退化的概念。
void f(int s[5])
{
memset(s, 0, sizeof(s));
}
int main()
{
int s[] = {1,2,3,4,5};
f(s);
for (int i = 0; i < 5; ++i)
cout << s[i] << ' ';
cout << endl;
system("pause");
}
上面这段程序的输出是:0 2 3 4 5
2、memset第一个参数是开始填充的地址,第二个参数是填充的byte,第三个参数要填充的字节数(注意是字节数)。
如果对int使用memset赋1,那么赋值的结果应该是00000001000000010000000100000001,为16843009。
---------------------
数组的名就是数组首元素的地址,所以
&a[0] 即是 a
------------------------------------
sizeof()
对于静态数组,sizeof可直接计算数组大小
例:int a[10];
sizeof(a)等于4*10=40
sizeof不能求得动态分配的内存的大小
int *p;
sizeof(*p)相当于sizeof(int);
sizeof(p)=4 地址占4字节
为什么sizeof可以知道数组的长度呢?网上说:
因为数组这种结构保存了数组的大小,有的书说数组长度保存在数组首地址前面的内存中。
尚待验证?
---------------------------------------
snprintf
函数原型:int snprintf(char *dest, size_t n, const char *fmt, ...);
函数说明: 最多从源串中拷贝n-1个字符到目标串中,然后再在后面加一个0。
类似sprintf,但是更安全,因为有n限制,不会溢出。dest是起始地址。
vc++里是 _snprintf
2015.01.04
bzero 在非linux上(比如嵌入式机)不可用,使用memset替换。