C语言中用malloc/free; C++里用new/delete;

1:C语言动态申请一维数组:

#include<stdio.h>
#include<stdlib.h>
int main()
{
    int i=0;
    int m=9;
    int *p = (int*)malloc(sizeof(int)*m);
    for(;i<m; ++i)
    {
        p[i] =i;
    }
    for(i=0;i<m; ++i)
    {
        printf("%d ",p[i]);
    }

free(p);
    return 0;
}

运行结果 0 1 2 3 4 5 6 7 8 请按任意键继续… 
2:C语言动态申请二维数组

#include<stdio.h>
#include<stdlib.h>
#include<vld.h>
int main()
{
    int i=0;
    int j=0;
    int tmp = 0;
    int m=4;//行
    int n  = 5;//列
    int **p = (int**)malloc(sizeof(int*)*m); //先动态申请行

for(;i<m; ++i)
    {
        p[i] = (int *)malloc(sizeof(int)*n); //在动态申请列;p[i]的类型是int*  即整型指针;
    }

for(i=0;i<m; ++i) //给二维数组赋值
    {
        for(j=0;j<n;++j)
        {
            p[i][j] = tmp;
            tmp++;
        }
    }

for(i=0;i<m; ++i)//显示二维数组的值
    {
        for(j=0;j<n;++j)
        {
            printf("%4d  ",p[i][j]);
        }
        printf("\n");
    }

for(i=0; i<m;++i)
    {
        free(p[i]);
    }
    free(p);//必不可少
    return 0;
}

运行结果: 
0 1 2 3 4 
5 6 7 8 9 
10 11 12 13 14 
15 16 17 18 19 
请按任意键继续… 
如果没有最后free(p);实际上会造成内存泄漏的;用内存检测工具vld检测结果如下: 
WARNING: Visual Leak Detector detected memory leaks!(检测到内存泄漏) 
———- Block 72 at 0x01014220: 16 bytes ———- 
Call Stack: 
Data: 
70 42 01 01 00 3D 01 01 50 3D 01 01 A0 3D 01 01 pB…=.. P=…=..

Visual Leak Detector detected 1 memory leak.

而加上free(p)后,结果如下: 
No memory leaks detected.(未发现内存泄漏)

3:C++动态申请一维数组

#include<iostream>
#include<vld.h>//内存检测工具,不包含也可以运行
using namespace std;

int main()
{
    int i=0;
    int m=9;
    int *p = new int[m];//申请空间
    for(i=0;i<m;++i)//赋值
    {
        p[i] =i;
    }

for(i=0; i<m; ++i)//显示
    {
        cout<<p[i]<<" ";
    }
    cout<<endl;
    delete []p;//释放内存 [] 里没有任何数字
    return 0;
}

4:动态申请二维数组

#include<iostream>
#include<iomanip>
#include<vld.h>
using namespace std;

int main()
{
    int m=4;
    int n=5;
    int i=0;
    int j=0;
    int tmp=0;
    //方法一
    int **p = new int*[m];
    for(i=0;i<m;++i)
    {
        p[i] = new int[n];
    }

for(i=0;i<m;++i)
    {
        for(j=0;j<n;++j)
        {
            p[i][j] = tmp;
            tmp++;
        }
    }
    for(i=0;i<m;++i)
    {
        for(j=0;j<n;++j)
        {
            cout<<p[i][j]<<setw(3);
        }
        cout<<endl;
    }

for(i=0;i<m;++i)
    {
        delete []p[i];
    }

delete p;

//方法2
    int (*q)[10] = new int[3][10];

for(int i=0;i<3;++i)
    {
        for(int j=0;j<10;++j)
        {
            q[i][j] = tmp++;
        }
    }

for(int i=0;i<3;++i)
    {
        for(int j=0;j<10;++j)
        {
            cout<<q[i][j]<<setw(3);
        }
        cout<<endl;
    }

delete []q;//与第一种方法不一样

return 0;
}
--------------------- 
作者:IM-STONE 
来源:CSDN 
原文:https://blog.csdn.net/doubleintfloat/article/details/52213158 
版权声明:本文为博主原创文章,转载请附上博文链接!

C/C++动态申请空间方式相关推荐

  1. 什么是指针以及如何动态申请空间

    int a;int *p;第一个比较熟悉,就是定义一个整型变量.第二个就是定义了一个整型指针变量p: 1.指针有什么作用? 指针是存储一个地址!注意是地址,不是什么具体的数值. 2.指针如何才能存储变 ...

  2. 关于C/C++动态申请空间释放和内存泄漏问题介绍

    1. 动态申请空间 1.1 基本内容 Ⅰ 动态申请的空间没有具体名称,只能通过指针间接访问(无论new还是malloc方式). Ⅱ 动态申请空间都是存放在堆中,有别于系统自动分配的空间是存放在堆栈中( ...

  3. C++ 动态申请空间

    目录 C中的动态申请空间 C++动态申请空间 new一个整型 申请空间的同时,给定初始化值 new 数组 返回的是首元素的首地址 释放数组空间时,不管是几维数组,只需要在指针前加一个[] new 整型 ...

  4. 走进C++程序世界-----指针(动态申请空间和释放空间)

    使用关键字NEW分配内存 在讲解分配内存之前,首先来理解下内存区划分.内存分配.常量存储区.堆.栈.自由存储区.全局区这些也是初学者容易混淆的地方.我的博客中有一篇文章描述C语言中代码分配情况,点击链 ...

  5. C语言如何动态申请空间(一维和二维)

    C语言如何动态申请一维和二维空间呢? 这里有个小例子,看过后就很容易理解 编译环境为vs2013 #include <stdio.h> #include <stdlib.h> ...

  6. C/C++动态申请空间

    C语言中用malloc/free: C++里用new/delete; 1:C语言动态申请一维数组: #include<stdio.h> #include<stdlib.h> i ...

  7. 【C语言】动态申请空间

    在很多情况下,我们不知道所要建立数组的大小,而是想根据需求动态的建立数组.但是通常使用 int arr[n] 这样的写法编译器会报错,因为n是变量. int n = 10; int array[n]; ...

  8. c++中动态申请空间的它们——new和delete

    今天重点说的是delete的一个小区别~~~ c++中对new申请的内存释放方式有delete和delect[]两种方式,那么这两种方式具体该怎么理解呢? 我们都知道,在c++中用new分配内存,用d ...

  9. C++学习之路抓紧跑路版(七)-动态申请内存空间

    文章目录 前言 一.如何申请动态内存空间? 二.练习 总结 前言 今天我们来看下在C++中如何动态申请内存空间,不多比比 一.如何申请动态内存空间? 在C++中我们用new/delete来申请和释放内 ...

最新文章

  1. 人工智能值得关注的技术研究方向
  2. 未能加载文件或程序集“AspNetPager”或它的某一个依赖项。拒绝访问。(异常来自 HRESULT:0x80070005 (E_ACCESSDENIED))...
  3. Java编程基础-变量
  4. 【Hibernate】Hibernate实体关系映射——单边的一对一关系
  5. kaggle (02) - 房价预测案例(进阶版)
  6. 区块链2.0——以太坊
  7. DOM操作style样式——link、style、p style=''的区别
  8. 数据库、SID实例、Oracle数据库、sys、system用户
  9. ps cs6选择并遮住在哪
  10. h5前端兼容性问题及解决方法集合
  11. 你珍藏多年,不舍得分享的网站有哪些?
  12. Prumo、bp和西门子与SPIC就巴西能源项目达成合作伙伴关系
  13. php如何pfx转成jks证书,常规方法不行,变相来实现
  14. 《7天精通直播带货》运营型主播成长型,提升直播能力与技巧
  15. 医学院校教师备课系统的信息安全性研究
  16. Centos7 下nexus的安装和使用
  17. SISR深度学习主要方法简述
  18. 重学数据结构与算法系列:这玩意叫跳表?
  19. 为何全色影像分辨率高于多光谱影像分辨率
  20. OCR文本检测模型—SegLink

热门文章

  1. 超微服务器主板ipmi证书,超微主板的服务器使用IPMI远程安装操作系统教程
  2. 美容仪皮秒机Lumina电源维修CCPF-4000
  3. 佛经小故事--《盲龟浮木》
  4. 全球60个线上学习资源网站分享!
  5. mysql中复杂sql语句之多重if嵌套语句
  6. Linux编程技术总结
  7. [Err] 23000 - [SQL Server]不能在具有唯一索引 'IX_student_info_2' 的对象 'dbo.student_info' 中插入重复键的行
  8. 软件测试面试题之非技术面试(GZH:软件测试大本营)
  9. 镜像在国外仓库,拉取不了怎么办
  10. 在网页项目中集成扫码枪设备,实现二维码扫码识别实战