您好,登錄后才能下訂單哦!
#include <iostream>
#include <cstdlib>
template <typename T>
class Array {
private:
T* m_data;
size_t m_size;
static void* m_memoryPool;
static size_t m_memoryPoolSize;
static size_t m_memoryPoolPosition;
public:
Array(size_t size) : m_size(size) {
if (m_memoryPool == nullptr) {
m_memoryPoolSize = size * sizeof(T);
m_memoryPool = std::malloc(m_memoryPoolSize);
m_memoryPoolPosition = 0;
}
m_data = reinterpret_cast<T*>(static_cast<char*>(m_memoryPool) + m_memoryPoolPosition);
m_memoryPoolPosition += size * sizeof(T);
}
~Array() {
// Do not free memory pool in destructor
}
T& operator[](size_t index) {
return m_data[index];
}
size_t size() const {
return m_size;
}
};
template <typename T>
void* Array<T>::m_memoryPool = nullptr;
template <typename T>
size_t Array<T>::m_memoryPoolSize = 0;
template <typename T>
size_t Array<T>::m_memoryPoolPosition = 0;
int main() {
Array<int> arr1(5);
Array<double> arr2(3);
for (int i = 0; i < arr1.size(); ++i) {
arr1[i] = i * 10;
}
for (int i = 0; i < arr2.size(); ++i) {
arr2[i] = i * 3.14;
}
for (int i = 0; i < arr1.size(); ++i) {
std::cout << arr1[i] << " ";
}
std::cout << std::endl;
for (int i = 0; i < arr2.size(); ++i) {
std::cout << arr2[i] << " ";
}
std::cout << std::endl;
return 0;
}
在這個(gè)示例中,我們定義了一個(gè)名為Array
的模板類,該類支持自定義內(nèi)存池。類中的靜態(tài)成員變量m_memoryPool
用于存儲(chǔ)分配的內(nèi)存池,m_memoryPoolSize
用于存儲(chǔ)內(nèi)存池的大小,m_memoryPoolPosition
用于跟蹤內(nèi)存池中下一個(gè)可用位置。在類的構(gòu)造函數(shù)中,我們首先檢查內(nèi)存池是否已分配,如果未分配則分配內(nèi)存池,并將數(shù)據(jù)存儲(chǔ)在內(nèi)存池的下一個(gè)可用位置。在類的析構(gòu)函數(shù)中,我們沒(méi)有釋放內(nèi)存池,因?yàn)閮?nèi)存池是靜態(tài)的,應(yīng)該在程序結(jié)束時(shí)釋放。在main
函數(shù)中,我們創(chuàng)建了兩個(gè)不同類型的Array
對(duì)象,并分別對(duì)其進(jìn)行賦值和打印。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。