关闭

初始化:普通数组 vs 指针数组 => sizeof, memset

标签: 编译器output化工gcc百度工具
2454人阅读 评论(0) 收藏 举报
分类:
   typedef TYPE;

   TYPE * pArray = new TYPE[100];
   memset(pArray, 0, 100*sizeof(TYPE));
   //memset(pArray, 0, sizeof(pArray)); //error, output: sizeof(pArray) = 4;

   TYPE tArray[100];
   memset(tArray, 0, sizeof(tArray)); //memset(&tArray, 0, sizeof(tArray)) is also Ok!


Attention ! :::::

memset是按字节来设置的,也就是,00000000,比如下面的问题:

【摘自:http://www.cnblogs.com/fengyuehan/archive/2012/02/03/memset.html

memset相信总是用c的童鞋不会陌生

百度百科给的定义是:将s所指向的某一块内存中的每个字节的内容全部设置为ch指定的ASCII值, 块的大小由第三个参数指定,这个函数通常为新申请的内存做初始化工作, 其返回值为指向S的指针。

原先我总是以为memset是初始化数组的最好方式,比for帅得多,直到最近做了一道题才发现不是这样的。。

比如:

#include <stdio.h>
#include <stdlib.h>
int main(int argc, char** argv) {

    int a[5];
    int i;
    memset(a,2,sizeof(a));
    for(i=0;i<5;i++)
    {
        printf("%d \n",a[i]);
    }
    return (EXIT_SUCCESS);
}

运行结果;


 

memset是把每个字节的全部内容替换成2,于是int的4个字节(不同编译器可能不一样)就替换成了

00000010 00000010 00000010 00000010 了,把它换成十进制后就成了2^1+2^9+2^17+2^25

我算数差,只能靠程序了,代码如下:

#include <stdio.h>
#include <stdlib.h>
#include <math.h>
int main(int argc, char** argv) {

    printf("%lf",pow(2,1)+pow(2,9)+pow(2,17)+pow(2,25));
    return (EXIT_SUCCESS);
}

运行结果:


而0和-1还是可以用memset的,因为0补完了就是 00000000 00000000 00000000 00000000 还是0

                  -1是 11111111 11111111 11111111 11111111  还是-1

代码:

#include <stdio.h>
#include <stdlib.h>
int main(int argc, char** argv) {

    int a[5],b[5];
    int i;
    memset(a,-1,sizeof(a));
    memset(b,0,sizeof(b));
    for(i=0;i<5;i++)
    {
        printf("%d    %d\n",a[i],b[i]);
    }
    return (EXIT_SUCCESS);
}

运行结果:

结论:memset在初始化int类型数据时,只能初始化-1和0时才能得到原值,根据定义,它应该是主要初始化字符数组的工具。


看见了吧,这就是memset的作为了。。。。。


附注:

bool flag[10];
memset(flag, false, sizeof(flag));



0
1

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:39379次
    • 积分:570
    • 等级:
    • 排名:千里之外
    • 原创:18篇
    • 转载:3篇
    • 译文:0篇
    • 评论:0条