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;
    }
}

Stay updated

Receive insights on tech, leadership, and growth.

Subscribe if you want to read posts like this

No spam. One email a month.

Leave a Reply

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.