首頁 > 後端開發 > C#.Net教程 > C++中動態記憶體分配與命名空間介紹

C++中動態記憶體分配與命名空間介紹

青灯夜游
發布: 2019-03-28 13:15:16
轉載
2316 人瀏覽過

這篇文章帶給大家的內容是介紹C 中的動態記憶體分配與命名空間,有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。

1、C 中的動態記憶體分配

# ● 透過new關鍵字進行動態記憶體申請

# ● C 中的動態記憶體申請時基於型別進行的

 ● delete關鍵用於記憶體釋放

C語言其實是不支援動態記憶體分配的,是透過malloc函式庫函數來實現的,可能有一些硬體根本不支援malloc;而C new是一個關鍵字,不管在任意編譯器上,任意硬體平台上都是能夠進行動態記憶體分配的,這就是本質區別。

malloc是基於位元組來進行動態記憶體分配的,new#則是基於類型來進行動態記憶體分配

// 变量申请:
Type * pointer = new Type;    // 从堆空间获取一个新的Type类型的空间
// 使用和C语言一样
delete pointer;        // 这里指的是pointer所指向的那个元素的内存空间被释放

// 数组申请:
Type * pointer = new Type[N];    // N指数组大小,数组元素个数,并非字节数
// 
delete[] pointer;    // 数组的释放,需要在delete后面加[],和变量有区别
                    // delete[]  说明所要释放的指针是指向一片数组空间的,释放整个数组空间,如果用delete的话,pointer指向的是数组的首元素地址,释放的就是首元素的内存空间,其余元素的内存空间并没有释放,会造成内存泄漏
登入後複製
#include <stdio.h>

int main()
{
    int* p = new int;    
    
    *p = 5;
    *p = *p + 10;
    
    printf("p = %p\n", p);
    printf("*p = %d\n", *p);
    
    delete p;        // 指释放单个变量
    
    p = new int[10]; // p指向一片数组空间,
    // p所指向的内存空间,至少占用了40个字节,保证够用,可能分配得更多
    
    for(int i=0; i<10; i++)
    {
        p[i] = i + 1;
        
        printf("p[%d] = %d\n", i, p[i]);
    }
    
    delete[] p;    // 释放数组
    
    return 0;
}
登入後複製

new關鍵字與malloc函數的差異:

 ● new關鍵字是C 的一部份

## ● 

malloc

是由C函式庫提供的函數

 ● 

new

以特定的型別為單位進行記憶體分配

 ● 

malloc

以位元組為單位進行記憶體分配

 ● 

new

在申請單一類型變數時可以進行初始化

 ● 

malloc

不具備記憶體初始化的特性

new

關鍵字的初始化:

int*   pi = new int(1);
float* pf = new float(2.0f);
char*  pc = new char('c')l
登入後複製
#2、C 中的命名空間

在C語言中只有一個全域作用域

 ● C語言所有的全域標識符共享同一個作用域

 ● 標識符之間可能發生衝突

#C 中提出了命名空間的概念

 ● 命名空間將全域作用域分成不同的部分

 ● 不同命名空間中的標識符可以同名而不會發生衝突

# ● 命名空間可以互相嵌套

 ● 全域作用域也叫預設命名空間#######定義:###
namespace Name
{
    namespace Internal
    {
        /* ... */
    }
    /* ... */
}
登入後複製
###命名空間的使用###
using namespace name;     // 使用整个命名空间
using name::variable;     // 使用命名空间中的变量
::variable;                // 使用默认命名空间中的变量
登入後複製
#include <stdio.h>

namespace First
{
    int i = 0;
}

namespace Second
{
    int i = 1;
    
    namespace Internal
    {
        struct P
        {
            int x;
            int y;
        };
    }
}

int main()
{
    using namespace First;
    using Second::Internal::P;
    
    printf("First::i = %d\n", i);
    printf("Second::i = %d\n", Second::i);
    
    P p = {2, 3};
    
    printf("p.x = %d\n", p.x);
    printf("p.y = %d\n", p.y);
    
    return 0;
}
登入後複製
###命名空間解決了全域變數命名衝突的問題#########3、小結#############C 中內建了動態記憶體分配的專用關鍵字#######C 中的動態記憶體分配可以同時進行初始化######C 中的動態記憶體分配時基於類型進行的#######C 中命名空間概念用於解決名稱衝突問題#########相關影片教學推薦:《###C 教學###》######以上就是這篇文章的全部內容,希望能對大家的學習有所幫助。更多精彩內容大家可以追蹤php中文網相關教學欄位! ! ! ###

以上是C++中動態記憶體分配與命名空間介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:segmentfault.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板