Форум программистов, компьютерный форум CyberForum.ru

Динамическое распределение памяти - C++

Восстановить пароль Регистрация
 
csrnsdrfg1
4 / 4 / 0
Регистрация: 30.03.2012
Сообщений: 34
28.06.2012, 13:35     Динамическое распределение памяти #1
Ни разу не работал с динамическим распределением. Объясните пжл, что я сделал не так. Цель - получить большую область памяти (состоящей из небольших кусков) для того, чтобы потом использовать ее для хранения текста. Прошу объяснить именно на примере malloc (), а не new/free;
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
#define check if (!text [i]) {printf ("\n NO MEMORY"); return 0;}
 
int main ()
{
char** text [1024] = {};
 
for (int i = 0; i < 1024; i++)
    {
    text [i] = (char**) malloc (1024);         
    check                                            
    for (int j = 0; j < 1024 /index; j++)
         {
         text [i] [j] = (char*) malloc (100);    
         check
         }
    }
/*Собственно попытка использования памяти. На некотором этапе срабатывает sigsegv*/
while (1) scanf ("%s", text [rand () %1024] [rand () %1024]);
 
/*Альтернативный вариант проверки*/
/*
for (int i = 0; i < 1024; i++)
    for (int j = 0; j < 1024; j++)
        for (int k = 0; k < 100; k++)
            if (k == 99) text [i] [j] [k] = '\0';
                else text [i] [j] [k] = rand ();
*/
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
28.06.2012, 13:35     Динамическое распределение памяти
Посмотрите здесь:

C++ Динамическое распределение памяти
Динамическое распределение памяти C++
C++ Динамическое распределение памяти
C++ Динамическое распределение памяти
C++ Динамическое распределение памяти
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
asidorchenko
379 / 205 / 25
Регистрация: 09.04.2012
Сообщений: 635
28.06.2012, 14:45     Динамическое распределение памяти #2
Вот пример выделения:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
#include <stdio.h>
#include <malloc.h>
#include <stdlib.h>
#include <time.h>
 
int main ()
{
char** text;
int i,j;
 
text = (char**) malloc(10*sizeof(char*));
 
for(i=0;i<10;i++)
 text[i] = (char*) malloc(3*sizeof(char));
 
for(i=0;i<10;i++)
 for(j=0;j<3;j++)
  text[i][j] = (char)i+j+'a';
 
 
for(i=0;i<10;i++, printf("\n"))
 for(j=0;j<3;j++)
  printf("%c ", text[i][j]);
 
return 0;
}
csrnsdrfg1
4 / 4 / 0
Регистрация: 30.03.2012
Сообщений: 34
28.06.2012, 14:51  [ТС]     Динамическое распределение памяти #3
asidorchenko, а в чем различие моего кода от вашего? В моем случае и 1024 и 100 кратно sizeof (void*) (в моей сис-ме размер указателя 4байта).
asidorchenko
379 / 205 / 25
Регистрация: 09.04.2012
Сообщений: 635
28.06.2012, 15:33     Динамическое распределение памяти #4
Мой код это просто пример выделения памяти и к вашему отношения не имеет.

Попробуйте заменить строку
C++
1
text [i] = (char**) malloc (1024);
на
C++
1
text [i] = (char**) malloc (1024*sizeof(char*));
csrnsdrfg1
4 / 4 / 0
Регистрация: 30.03.2012
Сообщений: 34
28.06.2012, 22:35  [ТС]     Динамическое распределение памяти #5
Блин, что-то я вообще невнимательный. Конечно, вы правы. Ведь 1024 байта это 1024 /4 указателей, а в проверке я использовал остаток отделения на 1024. Вот, дурак)
Yandex
Объявления
28.06.2012, 22:35     Динамическое распределение памяти
Ответ Создать тему
Опции темы

Текущее время: 22:51. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru