zoukankan      html  css  js  c++  java
  • C语言中的内存分配深入

    C语言中的内存分配深入


    这里不讲解c语言的内存分配怎么使用,只说要注意的问题。我们借用一下c++的,先看一个c++的内存分配:


    #include <iostream>
    using namespace std;
    struct cpp_Format
    {
        float pData[5];
    };
    cpp_Format ** c_pp;
    int main()
    {
        int i;
        c_pp = new cpp_Format* [10];
        for (i=0; i < 10; i++)
            c_pp[i] = new cpp_Format[20];
        for (i=0; i < 10; ++i)
            delete[] c_pp[i];
        delete[] c_pp;
        return 0;
    }


     

    那我们模仿一下,把他做成c语言的样子:

    #include <stdlib.h>
    #include <stdio.h>
    int main( void )
    {
       int *p1 = (int *)malloc(10);
       free(p1);
       int **p = NULL;
       p = (int **)malloc(10);
       for (int i = 0; i < 10; i++) {
         p[i] = (int *)malloc(10);
       }
       for (int i = 0; i < 10; i++) {
         free(p[i]);
       }
       free(p);
    }

    问题就出来,上面的程序编译起来没有问题,运行起来问题就大了。其实我们要知道,c++里面比如:

    c_pp = new cpp_Format* [10];

    这个10表示分配10个cpp_Format对象需要的空间。

    再看看

    int *p1 = (int *)malloc(10)

    真正理解malloc的就晓得,这个不是分配10个对象空间,仅仅是分配10个字节。

    那么10字节分配之后p1怎么用,从p[0]到p[9]?明显不是,一个int占4个字节,10个就是两个半int,哈哈这个就不好用了,p[0]到p[1.5]?无语!

    再看:

       int **p = NULL;
       p = (int **)malloc(10);
       for (int i = 0; i < 10; i++) {
         p[i] = (int *)malloc(10);
       }

    这个东西就有意思了,**p是10个字节,一个int *占4个字节,那么同样10/4之后就肯定没有10个分配好的指针,之所以编译不出错,是因为指针偏移不会越界。

    p[i] = (int *)malloc(10);

    这个也是问题,用p[i][2]有多用p[i][3]又不够!

    其实解决方法很简单:不要偷懒!

    修改如下:

    #include <stdlib.h>
    #include <stdio.h>
    int main( void )
    {
       int *p1 = (int *)malloc(10 * sizeof(int) );
       free(p1);
       int **p = NULL;
       p = (int **)malloc(10* sizeof(int *));
       for (int i = 0; i < 10; i++) {
         p[i] = (int *)malloc(10 * sizeof(int ) );
       }
       for (int i = 0; i < 10; i++) {
         free(p[i]);
       }
       free(p);
    }

    C和c++内存分配那个更好,不好说,实现的问题。

    本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/ztz0223/archive/2008/04/17/2299397.aspx

  • 相关阅读:
    (0)git安装
    [SCOI2008]奖励关
    bzoj1007 [HNOI2008]水平可见直线
    【bzoj1060】[ZJOI2007]时态同步
    【bzoj2705】[SDOI2012]Longge的问题
    【bzoj3505】[Cqoi2014]数三角形
    【bzoj3747】[POI2015]Kinoman
    P1072 Hankson的趣味题
    poj1845 数论 快速幂
    【bzoj1965】[Ahoi2005]SHUFFLE 洗牌
  • 原文地址:https://www.cnblogs.com/yanglin1228/p/4812066.html
Copyright © 2011-2022 走看看