• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

[C] Dwuwymiarowa dynamiczna tablica char - usuwanie

Object Storage Arubacloud
+1 głos
1,088 wizyt
pytanie zadane 15 kwietnia 2018 w C i C++ przez Stasq Nowicjusz (150 p.)

Cześć,

Natknąłem się na pewien problem, którego nie mogę rozgryźć, podczas czyszczenia pamięci dwuwymiarowej dynamicznej tablicy charow. 

W przypadku tablicy intów wygląda to tak i jest okej.

int **tab;
tab=(int**)malloc(sizeof(int*));
tab[0]=(int*)malloc(2*sizeof(int));
tab[1]=(int*)malloc(2*sizeof(int));
tab[2]=(int*)malloc(2*sizeof(int));

int i;
for(i=2;i>-1;i--)
free(tab[i]);

free(tab);

Ale gdy zmienię z int na char program się krzaczy

char **choices;
choices=(char**)malloc(sizeof(char*));
	choices[0]=(char*)malloc(25*sizeof(char));
	choices[1]=(char*)malloc(25*sizeof(char));
	choices[2]=(char*)malloc(25*sizeof(char));
	choices[3]=(char*)malloc(25*sizeof(char));
	choices[4]=(char*)malloc(25*sizeof(char));
	choices[5]=(char*)malloc(25*sizeof(char));


int i;
for(i=5;i>-1;i--)
free(choices[i]);

free(choices);

Jeśli to coś zmienia to dodam, że piszę na linuxie.

2 odpowiedzi

0 głosów
odpowiedź 15 kwietnia 2018 przez Ehlert Ekspert (212,670 p.)
int **tab;
tab=(int**)malloc(sizeof(int*));
tab[0]=(int*)malloc(2*sizeof(int));
tab[1]=(int*)malloc(2*sizeof(int));

Rezerwujesz pamięć dla sizeof(int*). To pamięć dla jednego wskaźnika. W czwartej linijce odwołujesz się do drugiego miejsca?

komentarz 15 kwietnia 2018 przez Stasq Nowicjusz (150 p.)
Słuszna uwaga. Dzięki
0 głosów
odpowiedź 15 kwietnia 2018 przez mokrowski Mędrzec (155,460 p.)
#include <stdio.h>
#include <stdlib.h>

#define TABLE_SIZE 4

int main(void) {

    // Tworzenie... 
    int ** table = malloc(TABLE_SIZE * sizeof(int*));
    for(size_t row = 0; row < TABLE_SIZE; ++row) {
        table[row] = malloc(TABLE_SIZE * sizeof(int));
    }
    
    // Zerowanie
    for(size_t row = 0; row < TABLE_SIZE; ++row) {
        for(size_t col = 0; col < TABLE_SIZE; ++col) {
            table[row][col] = 0;
        }
    }

    // Użycie
    table[2][3] = 102;

    // Prezentacja
    for(size_t row = 0; row < TABLE_SIZE; ++row) {
        for(size_t col = 0; col < TABLE_SIZE; ++col) {
            printf("%8d", table[row][col]);
        }
        putchar('\n');
    }

    // Usunięcie
    for(size_t row = 0; row << TABLE_SIZE; ++row) {
        free(table[row]);
    }
    free(table);

    return EXIT_SUCCESS;
}

I to jest jeden z mniej wydajnych sposobów konstruowania takiej tablicy. Taka tablica jest wolniejsza niż alokowanie pamięci ciągłej i obliczanie indeksu.

Podobne pytania

0 głosów
0 odpowiedzi 125 wizyt
pytanie zadane 28 stycznia 2022 w C i C++ przez danielch Użytkownik (660 p.)
0 głosów
1 odpowiedź 206 wizyt
pytanie zadane 19 kwietnia 2020 w C i C++ przez julsonem Nowicjusz (120 p.)
0 głosów
1 odpowiedź 547 wizyt

92,547 zapytań

141,387 odpowiedzi

319,503 komentarzy

61,931 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...