例子
wchar_t wstr[4];
wmemset(wstr, 0, sizeof(wstr)); //这样做不正确,会照成数组越界访问。
wmemset(wstr, 0, sizeof(wstr)/sizeof(wchar_t)); //这样做才正确
原因说明
相信大家看完上面的例子就清楚了,如果不明白的话可以看一下
关于sizeof
sizeof()是编译器提供的关键字,在编译的时候会把它变成一个数值,具体变成多少要看括号里放的是什么
1、如果括号里放的是一个类型,那么它就是这个类型所占内存的字节数,如:
sizeof(char) == 1
sizeof(short) == 2
sizeof(int *) == 4
struct mystruct{
char a;
char b;
char c;
char d;
}
sizeof(mystruct) == 4
2、如果括号里放的是一个变量(不包括数组名),那么它就是这个变量所占字节数,如:
char c;
sizeof(c) == 1
char *p;
sizeof(p) == 4
3、如果括号里放的是一个数组名,那么它就是这个数组所占字节书,如:
short str[10];
wchar_t wstr[4];
sizeof(str) == 20
sizeof(wstr) == 8
关于wmemset
看一下函数实现吧:
wchar_t *
wmemset(wchar_t *ws, wchar_t wc, size_t n)
{
wchar_t *ows1 = ws;
if (n != 0) {
do {
*ws++ = wc;
} while (--n != 0);
}
return (ows1);
}
由于ws是wchar_t*类型,所以ws++的时候ws的值会增加2!
再看一下我们的错误代码吧
wchar_t wstr[4];
wmemset(wstr, 0, sizeof(wstr));
等同于
wmemset(wstr, 0, 8);
执行这个函数的时候,向wstr开始的地址往后写了8*2个0,数据越界了!