Heap-Allocated 2D Structures in C++
C++ öğrenirken en çok zorlanılan konulardan biri, işin mutfağı olan manuel bellek yönetimi ve pointer yapılarıdır. Bugün çoğu modern dil bizim için bellekle ilgilense de, C++ hâlâ düşük seviye kontrolün ne anlama geldiğini öğretmek için altın standarttır. Özellikle çift pointer (int**) kullanarak 2D dinamik dizi oluşturmak, bilgisayar biliminde veri yapılarının bellek üzerinde gerçekte nasıl tutulduğunu anlamamızı sağlar.
Bu örnekte:
- stack üzerinde değil, heap üzerinde dinamik bir 2D dizi oluşturuyoruz,
- her satır için ayrı bellek alanı ayırıyoruz,
- elemanları dolduruyoruz,
- bir fonksiyon aracılığıyla diziyi işliyoruz,
- ve en önemlisi, ayırdığımız belleği doğru şekilde serbest bırakıyoruz.
Bu, C++’ta bellek yönetimini anlamanın temel taşıdır:
Belleği sen ayırırsın, sen doldurursun, sen temizlersin.
Aşağıdaki kod, pointer mantığını, dinamik bellek tahsisini ve 2D veri yapılarının düşük seviyede nasıl işlendiğini gösteren sade ama çok öğretici bir örnektir.
#include <iostream>
using namespace std;
void printElements(int **haha, int size1, int size2);
int main() {
// Initialize the array sizes
const int size1 = 4, size2 = 3;
// Define a pointer to a pointer (for a 2D array)
int **ptr;
// Initialize the 2D array
ptr = new int*[size1];
for (int i = 0; i < size1; ++i) {
ptr[i] = new int[size2];
}
// Assign values to the 2D array and print them
for (int i = 0; i < size1; ++i) {
for (int j = 0; j < size2; ++j) {
ptr[i][j] = i + j; // Example assignment
}
}
// Print the elements using the function
printElements(ptr, size1, size2);
// Deallocate memory
for (int i = 0; i < size1; ++i) {
delete[] ptr[i];
}
delete[] ptr;
return 0;
}
void printElements(int **haha, int size1, int size2) {
cout << "Elements in the array:" << endl;
for (int i = 0; i < size1; ++i) {
for (int j = 0; j < size2; ++j) {
cout << haha[i][j] << " ";
}
cout << endl;
}
}
Tags :