С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.56/9: Рейтинг темы: голосов - 9, средняя оценка - 4.56
2 / 0 / 0
Регистрация: 21.03.2010
Сообщений: 22

Выделение памяти с использованием malloc

12.12.2011, 00:05. Показов 1959. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток В общем есть следующий класс:
C++
1
2
3
4
5
6
7
8
9
class Addres {
  char name[40];
  char street[40];
  char city[40];
  char state[3];
  char zip[10];
  Adress(char name, char street, char city, char state, char zip);
  ~Adress() {};
};
Также нужно реализовать двусвязный список, поискав по форуме нашла похожие темы и реализацию добавления сделала так:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
void DoubleList::Add(char name, char street, char city, char state, char zip) {
        Addres *tmp = (Addres*) malloc(sizeof(Adress));
        if (First == NULL) {
                tmp -> Pred = NULL;
                tmp -> Next = NULL;
                First = tmp;
        }
        else
                Last -> Next = tmp;
        tmp -> name = name;
        tmp -> street = street;
        tmp -> city = city;
        tmp -> state = state;
        tmp -> zip = zip;
        tmp -> Next = NULL;
        tmp -> Pred = Last;
        Last = tmp;
}
Программа слетает, при попытке добавить новый элемент. Ошибка в выделении памяти, т.к. с new все работает.. Как нужно правильно выделить память при помощи malloc?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
12.12.2011, 00:05
Ответы с готовыми решениями:

Выделение памяти malloc
Подскажите как мне выделить два массива через malloc, пробою вот так #include <iostream> #include <stdio.h> #include...

Выделение памяти malloc
не работает пример из лекции , там пример на доске такой написан - #include <stdlib.h> int main() { int...

Динамическое выделение памяти malloc()
Здравствуйте! Cкажите пожалуйста, как узнать каков максимальный объем памяти, который может выделить программа посредством функции...

5
204 / 205 / 16
Регистрация: 06.08.2011
Сообщений: 600
Записей в блоге: 1
12.12.2011, 00:11
char name, char street, char city, char state, char zip
это просто символы - 1 байт
tmp -> state = state;
тут присваивание адресу state значения байта.(как и в остальных случаях)
0
2 / 0 / 0
Регистрация: 21.03.2010
Сообщений: 22
12.12.2011, 00:35  [ТС]
Упс, прощу прощения, скопировала не тот код С char'ом возникали проблемы и я заменила типы на строковые..
0
DU
1500 / 1146 / 165
Регистрация: 05.12.2011
Сообщений: 2,279
12.12.2011, 00:56
а чем вас new не устраивает?
ф-ия add странная. зачем ей столько аргументов. можно ведь проще:
C++
1
2
3
4
void DoubleList::Add(const Adress& adr)
{
  Addres *tmp = new Adress(adr); // У вас ведь есть дефолтный конструктор копирования.
  ...
Это более правильный подход. Если у класса Address появится другой конструктор, вам не придется еще и специальную функцию добавления в список под этот конструктор писать. Создаете экземпляр объекта Adress и отдаете его ф-ии Add.

И вам правильно заметили. Конструктор у вас принимает чары а не строки. У ф-ии Add та же проблема.
0
2 / 0 / 0
Регистрация: 21.03.2010
Сообщений: 22
12.12.2011, 01:22  [ТС]
Спасибо, но мне нужно по заданию использовать функцию malloc для выделения памяти..
А насчет char' ов то, там везде строки, я просто не тот код скопировала..
Вот такой код:
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
class Addres {
  string name;
  string street;
  string city;
  string state;
  string zip;
  Adress(string name, string street, string city, string state, string zip);
  ~Adress() {};
};
 
void DoubleList::Add(string name, string street, string city, string state, string zip) {
        Addres *tmp = (Addres*) malloc(sizeof(Adress));
        if (First == NULL) {
                tmp -> Pred = NULL;
                tmp -> Next = NULL;
                First = tmp;
        }
        else
                Last -> Next = tmp;
        tmp -> name = name;
        tmp -> street = street;
        tmp -> city = city;
        tmp -> state = state;
        tmp -> zip = zip;
        tmp -> Next = NULL;
        tmp -> Pred = Last;
        Last = tmp;
}
0
DU
1500 / 1146 / 165
Регистрация: 05.12.2011
Сообщений: 2,279
12.12.2011, 01:37
Вы тут всех в заблуждение пытаетесь ввести. Этот код не компилируется.
C++
1
2
class Addres ...
Addres *tmp = (Addres*) malloc(sizeof(Adress));
В вашем коде, который вы не показываете присутствуют два разных класса Addres и Adress. Выделяете память под один класс, кастите к указателю на другой класс. У Addres нет мемберов с именами Pred и Next. В общем неразбериха.
Вот такой код не вылетает:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#include <stdlib.h>
 
struct Addres {
 
  char name[40];
  char street[40];
  char city[40];
  char state[3];
  char zip[10];
  Addres(char name, char street, char city, char state, char zip) {}
  ~Addres() {};
};
 
int main()
{
  Addres* tmp = (Addres*) malloc(sizeof(Addres));
  return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
12.12.2011, 01:37
Помогаю со студенческими работами здесь

Выделение памяти malloc realloc
мне задачу поставили, надо не используя stl, загрузить из файла данные. r - строки с - это столбцы выдается сообщение ...

Выделение памяти malloc приводит к неправильным расчетам
Есть функция которая постоянно вызывается для расчетов. Она работает правильно, до тех пор пока я в неё не добовляю очередную строчку...

Динамическое выделение памяти под структуру (malloc)
Нашел данное решение на этом форуме, но никак не могу понять как оно работает. Вот даны структуры: struct info // структура...

Выделение памяти через malloc и считывание данных
Здравствуйте. Имеется файл, в котором 6 чисел типа double. В программе имеется 2 массива. В 1-ый записываю все числа из файла, стоящие на...

Выделение памяти с использованием ключевого слова new и исключения
Где-то читал, что наличие в коде throw, даже в том случае когда нет try/catch может приводить к некоторым замедлению потому что где-то...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и источниками (напряжения, ЭДС и тока). Найти токи и напряжения во всех элементах. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru