Dynamische Speicherverwaltung für zweidimensionales Array



  • Danke!!!

    µngbd schrieb:

    Du kannst in C99 auch sagen:

    //wenn du ein Array mit x*y Elementen haben willst:
    int zahl[breite][hoehe];
    
    //Zugriff auf Element (x,y) geht dann so:
    zahl[x][y]
    

    Ist ja aber nicht dynamisch 😉

    Habe gerade hier (http://www.c-plusplus.net/forum/viewtopic-var-t-is-39489.html) noch eine super Lösung gefunden:

    int main()
    {
        const int FirstDim = 4;
        const int SecDim = 5;
        // 1. Schritt: Dynamische Array von Zeigern anlegen:
        int** p2DimArr = new int*[FirstDim];
    
        // 2. Schritt: An jeden Zeiger ein Array hängen
        for (int i = 0; i < FirstDim ; i++)
            p2DimArr[i] = new int[SecDim];
    
        // mit dem neuen 2-dimensionalen Array arbeiten
        p2DimArr[0][0] = 42;
        //...
    
        // alles wieder löschen
        for (int j = 0; j < FirstDim ; j++)
            delete [] p2DimArr[j] ;
        delete [] p2DimArr;
    }
    


  • Ist ja aber nicht dynamisch 😉

    Wieso nicht?



  • Ist ja aber nicht dynamisch 😉

    Doch in C99 gibt es (leider) dynamische Arrays.

    Habe gerade hier (http://www.c-plusplus.net/forum/viewtopic-var-t-is-39489.html) noch eine super Lösung gefunden:

    Welche Programmiersprache willst du denn nun programmieren? C oder C++? Wenn du C programmieren willst, dann schau nicht nach Antworten in der C++-FAQ. Denn der Code ist nicht C kompatibel (und dazu noch kein besonders gutes C++)! Wenn du C++ programmieren willst, dann stell die Frage im C++ und nicht im C Forum!



  • int** p2DimArr = new int*[FirstDim];

    Schade, new ist nicht deklariert. Was muss ich machen, damit das läuft?



  • µngbd schrieb:

    int** p2DimArr = new int*[FirstDim];

    Schade, new ist nicht deklariert. Was muss ich machen, damit das läuft?

    einen vernünftigen compiler benutzen, der das kann 😃



  • µngbd schrieb:

    int** p2DimArr = new int*[FirstDim];

    Schade, new ist nicht deklariert. Was muss ich machen, damit das läuft?

    new gibt es nur in C++. Hier bist Du im C-Forum. Also hier gibt es kein new. Willst Du mit Gewalt new nehmen, mußt Du eigentlich damit ins C++-Forum gehen. Aber Du könntest das, was man mit new macht, auch mit malloc machen. Daher die Frage: new oder malloc, was ist Dein Begehr?



  • Habe gerade hier (http://www.c-plusplus.net/forum/viewtopic-var-t-is-39489.html) noch eine super Lösung gefunden:

    Die ist aber grundlegend anders als die von _matze, nicht nur syntaktisch. Da hast du nicht einen Block, sondern mehrere, die mit Zeigern verbunden sind. Zwei Zeilen zu vertauschen geht somit schneller. Die Entscheidung zwischen den beiden sollte die Datenstruktur und nicht die Syntax zum Thema haben.



  • Also wenn ich diese Methode, die 'new' verwendet benutze, lässt sich das in meiner .c-Datei problemlos mit gcc compilieren 😕



  • vernuenftig0r schrieb:

    µngbd schrieb:

    int** p2DimArr = new int*[FirstDim];

    Schade, new ist nicht deklariert. Was muss ich machen, damit das läuft?

    einen vernünftigen compiler benutzen, der das kann

    aber der würde wiederum keine pointer kennen.
    🙂



  • Siegfried1 schrieb:

    Also wenn ich diese Methode, die 'new' verwendet benutze, lässt sich das in meiner .c-Datei problemlos mit gcc compilieren 😕

    Nein! new und delete sind Schlüsselwörter der Sprache C++. Wenn du C programmieren willst, musst die entsprechenden Äquivalente malloc und free benutzen (außerdem gibt's noch calloc und realloc, aber das nur am Rande).

    Also nochmal ganz klar: du kannst keine reinen C++-Sprachmittel in C benutzen! Nicht möglich (wird dir der Compiler auch sagen)! Es ist einfacher, Autoräder am Motorrad zu befestigen...



  • Basher schrieb:

    vernuenftig0r schrieb:

    µngbd schrieb:

    int** p2DimArr = new int*[FirstDim];

    Schade, new ist nicht deklariert. Was muss ich machen, damit das läuft?

    einen vernünftigen compiler benutzen, der das kann

    aber der würde wiederum keine pointer kennen.
    🙂

    Hmm Also mein C++-Compiler kennt pointer? 😃



  • rüdiger schrieb:

    Ist ja aber nicht dynamisch 😉

    Doch in C99 gibt es (leider) dynamische Arrays.

    Wieso "leider"?



  • Tim schrieb:

    rüdiger schrieb:

    Ist ja aber nicht dynamisch 😉

    Doch in C99 gibt es (leider) dynamische Arrays.

    Wieso "leider"?

    Ich finde VLAs sind ein unausgewogenes Feature. Es gibt keinen Weg für die Anwendung festzustellen, ob die Stackgrenzen gesprengt werden. Bei man: alloca gibt es ja immerhin noch den Weg, dass die Funktion das intern prüft und fehlschlägt (wobei zB die GCC/glib alloca Funktion leider noch nicht einmal das tut). Aber wie soll man in der Runtime bei einem VLA auf so ein Problem reagieren? (gar nicht? Programm abbrechen? Stack wieder herstellen? ...)



  • rüdiger schrieb:

    Tim schrieb:

    rüdiger schrieb:

    Ist ja aber nicht dynamisch

    Doch in C99 gibt es (leider) dynamische Arrays.

    Wieso "leider"?

    Ich finde VLAs sind ein unausgewogenes Feature. Es gibt keinen Weg für die Anwendung festzustellen, ob die Stackgrenzen gesprengt werden. Bei man: alloca gibt es ja immerhin noch den Weg, dass die Funktion das intern prüft und fehlschlägt (wobei zB die GCC/glib alloca Funktion leider noch nicht einmal das tut). Aber wie soll man in der Runtime bei einem VLA auf so ein Problem reagieren? (gar nicht? Programm abbrechen? Stack wieder herstellen? ...)

    das ist wie mit rekursionen. du musst vorher wissen, wie viel es maximal werden kann.
    🙂


Anmelden zum Antworten