zoukankan      html  css  js  c++  java
  • malloc和new的区别 begin

    http://blog.csdn.net/miss_acha/article/details/7279915#comments

    1.综述

    1,malloc与free是C++/C语言的标准库函数,new/delete是C++的运算符。它们都可用于申请动态内存和释放内存。

    2,对于非内部数据类型的对象而言,光用maloc/free无法满足动态对象的要求。对象在创建的同时要自动执行构造函数,对象在消亡之前要自动执行析构函数。由于malloc/free是库函数而不是运算符,不在编译器控制权限之内,不能够把执行构造函数和析构函数的任务强加于malloc /free.

    3,因此C++语言需要一个能完成动态内存分配和初始化工作的运算符new,以及一个能完成清理与释放内存工作的运算符delete。注意new/delete不是库函数。

    4,C++程序经常要调用C函数,而C程序只能用malloc/free管理动态内存

    new 是个操作符,和什么"+","-","="……有一样的地位。

    malloc是个分配内存的函数,供你调用的。

    new是保留字,不需要头文件支持。

    malloc需要头文件库函数支持。

    new 建立的是一个对象,

    malloc分配的是一块内存。

    new建立的对象你可以把它当成一个普通的对象,用成员函数访问,不要直接访问它的地址空间

    malloc分配的是一块内存区域,就用指针访问好了,而且还可以在里面移动指针。

    简而言之:

    new 是一个操作符,可以重载

    malloc是一个函数

    new 初始化对象,调用对象的构造函数,对应的delete调用相应的析构函数

    malloc仅仅分配内存,free仅仅回收内存

    2.三种形式的new表达式

    <1>单个对象的动态分配

    int *pi = new int(11); // initializer

    int *q = new int;   //assign

    *q = i;

    <2>数组的动态分配

    int *pi = new int[11];   // 分配有11个元素的动态数组

    int (*pia)[11] = new int [22][11];   //分配一个含有 22 * 11 个元素的二维数组

    • 动态分配的数组不能给出初始化值,一般在 for 循环中一个一个的初始化

    for(int i = 0; i < 11; i++)

          pi[i] = 0;

    • 动态数组的第一维不必是常量值, 这样就不必在编译时刻就知道维数,我们可以根据需要分配大小合适的内存单元
    • 释放动态数组:        delete [ ] pi;    如果不小心忘记了空括号,编译器不会捕捉到这个错误, 务必要小心
    • 一般为了避免动态分配数组带来的内存管理的问题, 我们使用c++ 的 标准库vector, list or string 会自动管理内存的容器类型

    ---------------------

    常量对象的动态分配

    const int *pic = new const int(1024);

    • const 对象必须被初始化, 否则会编译错误,(因此我们也不能创建const数组,因为const数组不能被初始化,除了类数组)
    • 用new表达式返回的值作为初始值的指针必须是一个指向const类型的指针. eg: const int
    • 它的生命期同样也用delete表达式来结束 eg: delete pic;

    <3>定位new表达式(placement new expression)

    形式: new (place_address) type-specifier

    头文件: #include <new>

    place_adress必须是指针

    eg:

    int *buf = new int[2];

    int *pb = new (buf) int;

    *pb = 11;

    cout << *pb << endl;             // 11

    cout << *buf << endl;            // 11

    cout << pb << endl;                 // 同样pb跟buf的所指向的地址也是相同的

    cout << buf << endl;                //

    int *pp = new (buf + 1) int;

    *pp = 22;

    • 因为定位符并不分配内存,所以我们并没有与定位符相匹配的delete表达式, 对此我们需要删除的是分配内存的指针,在上面的例子中我们 delete [] buf;new和delete运算符用于动态分配和撤销内存的运算符.

     

  • 相关阅读:
    Bugku-CTF之各种绕过
    算法竞赛入门经典 第四章 学习笔记 2
    时钟周期,CPU周期,指令周期,CPU时间片
    big-endian和little-endian
    android px,dp,sp大小转换工具
    SharedPreferences漏洞, 无法避免,所以不要在里面存储敏感信息
    java正则表达式入门
    adb命令
    android largeheap 的设定
    关于java中接口定义常量和类定义常量的区别
  • 原文地址:https://www.cnblogs.com/chulia20002001/p/6829064.html
Copyright © 2011-2022 走看看