使用wmemset函数的时候犯的错误

例子

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,数据越界了!

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值