C/C++堆區(qū)專篇精講
malloc
malloc開辟堆區(qū)內(nèi)存。頭文件stdlib.h,函數(shù)原形如下。
void*malloc(size_tsize); //返回值void指針,該指針就是開辟的內(nèi)存地址,參數(shù)是開辟的字節(jié)數(shù)。
free
free釋放堆區(qū)開辟的內(nèi)存。頭文件stdlib.h,函數(shù)原形如下。
voidfree(void*ptr); // 參數(shù)傳入需要釋放的堆區(qū)內(nèi)存首地址。
程序:
#include<iostream> #include<windows.h> using namespace std; int main() { int* p = (int*)malloc(20); //void* malloc(size) 返回自void指針,參數(shù)是字節(jié)數(shù) for (int i = 0; i < 5; i++) { p[i] = i; //*(p+i) = i; } cout << p[1] << " " << *(p + 1) << endl; if (p) { free(p); // void free(heap addr) } system("pause"); return 0; }
結(jié)果:
1 1
請(qǐng)按任意鍵繼續(xù). . .
C++ 中的new和delete是運(yùn)算符開辟和釋放堆區(qū)空間比C語言的malloc、free更高效,推薦使用。
new
返回堆區(qū)首元素的地址,可以開辟一個(gè)元素(開辟的時(shí)候可以賦值)、一維數(shù)組、二維數(shù)組。當(dāng)使用new開辟二維數(shù)組的時(shí)候需要特別注意,返回的是數(shù)組指針,所以需要數(shù)組指針去接收堆區(qū)地址。
delete
delete釋放堆區(qū)的時(shí)候數(shù)組需要加上[]
程序:
#include<iostream> #include<windows.h> using namespace std; int main() { int* p1 = new int(3); // 在堆區(qū)創(chuàng)建一個(gè)int類型數(shù)據(jù),并且賦初值 // int* p2 = new int(0, 1, 2, 3, 4); // 無法初始化數(shù)組 int* p3 = new int[4]; // 在堆區(qū)創(chuàng)建數(shù)組,不賦初值 int(*p4)[3] = new int[2][3]; // 在堆區(qū)創(chuàng)建二維數(shù)組 *(p3 + 1) = 1; cout << *p1 << endl; cout << *(p3 + 1) << endl; if (p1) { delete p1; } if (p3) { delete[] p3; } if (p4) { delete[] p4; } system("pause"); return 0; }
結(jié)果:
3
1 請(qǐng)按任意鍵繼續(xù). . .
memcpy
內(nèi)存拷貝函數(shù),從src源地址拷貝size字節(jié)到dest目標(biāo)地址
頭文件:cstring 函數(shù)原形
void*memcpy(void*dest,constvoid*src,std::size_tcount);
dest目標(biāo)地址,src源地址,size拷貝的字節(jié)數(shù)
代碼:
#include<iostream> #include<string> #include<windows.h> using namespace std; int main() { int num1[5] = { 0, 1, 2, 3, 4 }; int* p = new int[5]; memcpy(p, &num1, sizeof(num1)); cout << *(p + 2) << endl; if (p) { delete[] p; } system("pause"); return 0; }
結(jié)果:
2
請(qǐng)按任意鍵繼續(xù). . .
memset
用于初始化新開辟的堆區(qū)內(nèi)存,從dest目標(biāo)地址開始,size個(gè)字節(jié)設(shè)置成數(shù)據(jù)ch
頭文件:cstring 函數(shù)原形
void*memset(void*dest,intch,std::size_tcount);
dest目標(biāo)地址,ch需要設(shè)置的值,size字節(jié)數(shù)
程序:
#include<iostream> #include<windows.h> using namespace std; int main() { int* p = new int[5]; memset(p, 0, 5 * sizeof(int)); // 將新開辟的的堆區(qū)數(shù)組設(shè)成0 cout << *(p + 2) << endl; if (p) { delete[] p; } system("pause"); return 0; }
結(jié)果:
0
請(qǐng)按任意鍵繼續(xù). . .
到此這篇關(guān)于C/C++堆區(qū)專篇精講的文章就介紹到這了,更多相關(guān)C++堆區(qū)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語言實(shí)現(xiàn)簡(jiǎn)單通訊錄管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)簡(jiǎn)單通訊錄管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-07-07wince程序防止創(chuàng)建多個(gè)實(shí)例實(shí)現(xiàn)互斥作用
什么時(shí)候用的互斥?當(dāng)你的程序只允許同時(shí)打開一個(gè)的時(shí)候,就可以通過互斥來實(shí)現(xiàn),下面說的互斥,主要是針對(duì)防止程序創(chuàng)建多個(gè)實(shí)例這種情況來實(shí)現(xiàn)的2014-02-02C++實(shí)現(xiàn)打印兩個(gè)有序鏈表公共部分的方法
這篇文章主要介紹了C++實(shí)現(xiàn)打印兩個(gè)有序鏈表公共部分的方法,涉及C++針對(duì)有序鏈表的簡(jiǎn)單遍歷、比較相關(guān)操作技巧,需要的朋友可以參考下2017-05-05Window10下安裝VS2022社區(qū)版的實(shí)現(xiàn)步驟(圖文教程)
很多和同學(xué)們?cè)诮佑|c語言的時(shí)候都是使用VS,本文主要介紹了Window10下如何安裝VS2022社區(qū)版的實(shí)現(xiàn)步驟,具有一定的參考價(jià)值,感興趣的可以了解一下2024-02-02利用Qt實(shí)現(xiàn)仿QQ設(shè)置面板功能
這篇文章主要為大家詳細(xì)介紹了如何利用Qt實(shí)現(xiàn)仿QQ設(shè)置面板功能,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,感興趣的小伙伴可以了解一下2022-12-12