溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

C/C++堆區(qū)怎么應(yīng)用

發(fā)布時(shí)間:2022-10-27 16:35:05 來源:億速云 閱讀:98 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹“C/C++堆區(qū)怎么應(yīng)用”,在日常操作中,相信很多人在C/C++堆區(qū)怎么應(yīng)用問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”C/C++堆區(qū)怎么應(yīng)用”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!

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

請按任意鍵繼續(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 請按任意鍵繼續(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

請按任意鍵繼續(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

請按任意鍵繼續(xù). . .

到此,關(guān)于“C/C++堆區(qū)怎么應(yīng)用”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

c++
AI