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

Как происходит процесс выделения памяти в стеке и куче - C++

Восстановить пароль Регистрация
 
 
Рейтинг: Рейтинг темы: голосов - 16, средняя оценка - 4.94
Lers
12 / 12 / 3
Регистрация: 27.05.2012
Сообщений: 202
16.01.2014, 14:46     Как происходит процесс выделения памяти в стеке и куче #1
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
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
#include <stdio.h>
#include <conio.h>
#include <windows.h>
#include "disc.h"
void main()
{
  SetConsoleCP(1251);
  SetConsoleOutputCP(1251);
  
  Disc d1,d2[2];
  Disc *d3,*d4;
  d3=new Disc;
  int kol=0,n;
  clrscr();
  kol++;
  printf("%i)",kol);
  printf("\nВведите название дисциплины -> ");
  gets(d1.namedisc);
  printf("Введите имя перподавателя -> ");
  gets(d1.teacher_name);
  printf("Введите название группы -> ");
  gets(d1.name_group);
  printf("Введите кол-во часов на изуч. дисциплины-> ");
  scanf("%i",&d1.hours);
  fflush(stdin);
  
  for (int i=0; i<1; i++)
  {
    clrscr();
    kol++;
    printf("%i)",kol);
    printf("\nВведите название дисциплины -> ");
    gets(d2[i].namedisc);
    printf("Введите имя перподавателя -> ");
    gets(d2[i].teacher_name);
    printf("Введите название группы -> ");
    gets(d2[i].name_group);
    printf("Введите кол-во часов на изуч. дисциплины-> ");
    scanf("%i",&d2[i].hours);
    fflush(stdin);
  }
 
  clrscr();
  kol++;
  printf("%i)",kol);
  printf("\nВведите название дисциплины -> ");
  gets(d3->namedisc);
  printf("Введите имя перподавателя -> ");
  gets(d3->teacher_name);
  printf("Введите название группы -> ");
  gets(d3->name_group);
  printf("Введите кол-во часов на изуч. дисциплины-> ");
  scanf("%i",&d3->hours);
  fflush(stdin);
 
  printf ("\n Введите кол-во записей-> ");
  scanf ("%i",&n);
  d4=new Disc [n];
  fflush(stdin);
  for (int i=0; i<n; i++)
  {
    clrscr();
    kol++;
    printf("%i)",kol);
    printf("\nВведите название дисциплины -> ");
    gets(d4[i].namedisc);
    printf("Введите имя перподавателя -> ");
    gets(d4[i].teacher_name);
    printf("Введите название группы -> ");
    gets(d4[i].name_group);
    printf("Введите кол-во часов на изуч. дисциплины-> ");
    scanf("%i",&d4[i].hours);
    fflush(stdin);
  }
  clrscr();
  kol=0;
  printf("\n------------------------------------------------------------");
  printf("\n|№|Название дисциплины |Имя преподавателя   |Имя группы|Час|");
  printf("\n------------------------------------------------------------");
  kol++;
  printf("\n|%1i|%20s|%20s|%10s|%3i|",kol,d1.namedisc,d1.teacher_name,d1.name_group,d1.hours);
  for (int i=0; i<1; i++)
    printf("\n|%1i|%20s|%20s|%10s|%3i|",kol+i+1,d2[i].namedisc,d2[i].teacher_name,d2[i].name_group,d2[i].hours);
  kol+=3;
   printf("\n|%1i|%20s|%20s|%10s|%3i|",kol,d3->namedisc,d3->teacher_name,d3->name_group,d3->hours);
  for (int i=0; i<n; i++)
    printf("\n|%1i|%20s|%20s|%10s|%3i|",kol+i+1,d4[i].namedisc,d4[i].teacher_name,d4[i].name_group,d4[i].hours);
  kol+=2;  
  printf("\n------------------------------------------------------------");
  getch();
  delete d3;
  delete []d4;
}
C++
1
2
3
4
5
6
7
8
class Disc
{
  public:
  char namedisc[20];
  char teacher_name[20];
  char name_group[10];
  int hours;
};
Тут я просто вывожу в табличке свой класс, просто 4 способами, через переменную, массив, указатель и дин.массив. Вопрос вот выделении памяти под объекты класса (d1,d2[i],*d3,*d4);
писал sizeof для каждого объекта и получил что
d1=56 байта (тут вроде 3 chara 20+20+10+ 1 int=4 байтам=54 байта, куда выделяются еще 2 байта?)
d2=112 байта (ну тут понятно, что записей в массиве 2, 56+56=112)
d3=4 байта (тут 4 байта при записи sizeof(d3)-т.е. на каждое поле класса, их всего 4 выделяется по 1 байту?)
(а если написать sizeof(*d3) то будет снова 56 байт
d4=4 байта (тут аналогично)
Объясните пожалуйста, как происходит процесс выделения памяти в стеке и куче, ну и про кол-во байтов на объекты класса.
Все это делаю в C++ Builder 6
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.01.2014, 14:46     Как происходит процесс выделения памяти в стеке и куче
Посмотрите здесь:

Потоки и выделение памяти в куче C++
C++ Расположение данных в стеке и в куче
Нужно перевести из С++ в C строку с выделением памяти в куче C++
C++ Указатели (Выделение памяти в куче)
C++ Выделение памяти на стеке
C++ Не могу понять где объект в куче или в стеке !
Почему это компилируется, ведь под второй массив по идее не выделено в куче памяти C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
alsav22
5284 / 4803 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
16.01.2014, 19:35     Как происходит процесс выделения памяти в стеке и куче #21
Цитата Сообщение от Lers Посмотреть сообщение
это не моя прихоть так извращаться
А чья? Кто-то заставляет так писать?
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Lers
12 / 12 / 3
Регистрация: 27.05.2012
Сообщений: 202
16.01.2014, 19:51  [ТС]     Как происходит процесс выделения памяти в стеке и куче #22
Цитата Сообщение от alsav22 Посмотреть сообщение
А чья? Кто-то заставляет так писать?
Преподы издеваются, говорят если знаешь эти извращение, то имеешь понятие о выделение памяти в стеке, куче и т.п..

Добавлено через 2 минуты
Мм забыл про выравнивание....
Немного потестил сколько выделяется памяти на выравнивание типа int,double,long double
1) при int выделяется 2 байта на вырав.
2) при double 6 байт
3) при long double 12 байтов
Искал инфу про выравнивание написанное доступным языком, толкового не нашел.
Может кто знает, расскажите пожалуйста
ValeryS
Модератор
6403 / 4869 / 447
Регистрация: 14.02.2011
Сообщений: 16,159
16.01.2014, 20:11     Как происходит процесс выделения памяти в стеке и куче #23
Цитата Сообщение от Lers Посмотреть сообщение
Преподы издеваются, говорят если знаешь эти извращение, то имеешь понятие о выделение памяти в стеке, куче и т.п..
спроси у них
в таком коде
C++
1
2
3
void fnc(int a)
{
 int b
где разместятся a и b для процессоров( микроконтроллеров)
таких как Intel 8051 или Atmega8535
если ответят в стеке то можешь смело их посылать....... учится
нет там таких размеров стеков, в регистрах будут размешатся
и даже всеми любимяй 80х86 может спокойно расположить локальную переменную не в стеке а в регистрах
так что эти извраты не приведут тебя к пониманию

Добавлено через 7 минут
Цитата Сообщение от Lers Посмотреть сообщение
Мм забыл про выравнивание....
зависит от процессора и от настроек компилятора
выравнивание удобно процессору чтобы быстрее иметь доступ
так
8 битные процессоры будут выравнивать на на границу байта( отсутствует выравнивание)
16 битные на границу двух байтов
32 битные на границу четырех байтов
64 битные на границу 8 байтов
так адреса в структуре
C++
1
2
3
4
5
struct aa
{
char c;
int i;
}
могут быть
для 8 битного
c 0х00;
i 0х01;
для 16 битного
c 0х00;
i 0х02;
для 32 битного
c 0х00;
i 0х04;
для 64 битного
c 0х00;
i 0х08;

не знаю понятно ли объяснил?

Добавлено через 6 минут
Цитата Сообщение от Lers Посмотреть сообщение
при int выделяется 2 байта на вырав.
размер int 4 байта для 32 разрядных и 2 байта у 16 битных
размер int чаще всего привязан к разрядности процессора
Цитата Сообщение от Lers Посмотреть сообщение
при double 6 байт
размер double 8 байт
Цитата Сообщение от Lers Посмотреть сообщение
при long double 12 байтов
размер long double 10 байт ( правда микрософт на это плюет и размер long double у него тоже 8 байт)
для проверки размера существует sizeof возвращает размер в байтах
но никакого отношения размер переменных к выравниванию не имеет
Lers
12 / 12 / 3
Регистрация: 27.05.2012
Сообщений: 202
16.01.2014, 20:15  [ТС]     Как происходит процесс выделения памяти в стеке и куче #24
Залил картинку настроек билдера своего, я так понимаю то, что я выделил и есть настройка выравнивания?
мля ссылку не хочет вставлять.

Data aligment-> Quad word это выравнивание?

Добавлено через 3 минуты
Цитата Сообщение от ValeryS Посмотреть сообщение

размер int 4 байта для 32 разрядных и 2 байта у 16 битных
размер int чаще всего привязан к разрядности процессора

размер double 8 байт

размер long double 10 байт ( правда микрософт на это плюет и размер long double у него тоже 8 байт)
для проверки размера существует sizeof возвращает размер в байтах
но никакого отношения размер переменных к выравниванию не имеет
то что размер double 8 байт я знаю, в моей программе при использование double вместо int выделяется 6 байт на выравнивает и 12 байт при long double
ValeryS
Модератор
6403 / 4869 / 447
Регистрация: 14.02.2011
Сообщений: 16,159
16.01.2014, 20:15     Как происходит процесс выделения памяти в стеке и куче #25
Цитата Сообщение от Lers Посмотреть сообщение
мля ссылку не хочет вставлять
залей картинку
расширенный режим значок скрепки
правда я в Билдере не очень последний раз общался с продукцией Borland еще под DOS на BC3.1
alsav22
16.01.2014, 20:16
  #26

Не по теме:

Цитата Сообщение от Lers Посмотреть сообщение
Преподы издеваются, говорят если знаешь эти извращение, то имеешь понятие о выделение памяти в стеке, куче и т.п..
Такие извращения не относятся к понятиям. Есть понятия, суть, и есть синтаксис. Синтаксис позовляет одно и тоже записать самыми разными способами. Одни способы привычны, понятны, рациональны, другие - наоборот.

Lers
12 / 12 / 3
Регистрация: 27.05.2012
Сообщений: 202
16.01.2014, 20:18  [ТС]     Как происходит процесс выделения памяти в стеке и куче #27
Как происходит процесс выделения памяти в стеке и куче
Lers
12 / 12 / 3
Регистрация: 27.05.2012
Сообщений: 202
16.01.2014, 20:27  [ТС]     Как происходит процесс выделения памяти в стеке и куче #28
Byte — 8 бит
Word — 16 бит
Double Word — 32 бит
Quad Word — 64 бит
Octa Word — 128 бит
ValeryS
Модератор
6403 / 4869 / 447
Регистрация: 14.02.2011
Сообщений: 16,159
16.01.2014, 20:31     Как происходит процесс выделения памяти в стеке и куче #29
Цитата Сообщение от Lers Посмотреть сообщение
то что размер double 8 байт я знаю, в моей программе при использование double вместо int выделяется 6 байт на выравнивает и 12 байт при long double
а как узнал то?
и программа то эта?
Цитата Сообщение от Lers Посмотреть сообщение
class Disc
{
* public:
* char namedisc[20];
* char teacher_name[20];
* char name_group[10];
* int hours;
};
можешь сам посмотреть куда лягут переменные при разных режимах выравнивания и даже если поменяешь между собой члены
C++
1
2
3
4
5
6
7
8
9
10
11
Disc D;
void *addr=(void)&D;
void *addr_namedisc=(void)&D.namedisc[0];
void *addr_teacher_name=(void)&D.teacher_name[0];
void *addr_group=(void)&D_group[0];
void *addr_hours=(void)&D.hours;
print("offset namedisc=%x, offset teacher_name= %x offset name_group= %x offset hours=%x",
       addr_namedisc-addr,
       addr_teacher_name-addr,
       addr_group-addr,
       addr_hours-addr);
Добавлено через 1 минуту
Lers, судя по картинке у тебя выравнивание на 8 бит ( счетвереннное слово, а слово это два байта)
Lers
12 / 12 / 3
Регистрация: 27.05.2012
Сообщений: 202
16.01.2014, 20:36  [ТС]     Как происходит процесс выделения памяти в стеке и куче #30
ValeryS, да класс этот, sizeof и проверял.
т.е. 3 char,1 int =56
3 char, 1 long double=72
3 char, 1 double=64

Добавлено через 53 секунды
может на 8 байт?

Добавлено через 2 минуты
а может быть такое, что билдер растягивает размер для того чтобы размер был кратен 8 ( т.е. выравниванию)
ValeryS
Модератор
6403 / 4869 / 447
Регистрация: 14.02.2011
Сообщений: 16,159
16.01.2014, 20:49     Как происходит процесс выделения памяти в стеке и куче #31
Цитата Сообщение от Lers Посмотреть сообщение
может на 8 байт?
разумеется байт это я описался
Цитата Сообщение от Lers Посмотреть сообщение
а может быть такое, что билдер растягивает размер для того чтобы размер был кратен 8 ( т.е. выравниванию)
да так и происходит
только к каждому элементы структуры
например
Цитата Сообщение от Lers Посмотреть сообщение
char namedisc[20];
20 байт но 20 некратно 8 добавит 4 байта =24
Цитата Сообщение от Lers Посмотреть сообщение
char teacher_name[20];
20+4=24
Цитата Сообщение от Lers Посмотреть сообщение
char name_group[10];
10+6=16
Цитата Сообщение от Lers Посмотреть сообщение
int hours;
4+4=8
24+24+16+8=72
мдя чтото я общитался
Цитата Сообщение от Lers Посмотреть сообщение
3 char,1 int =56
такое значение может получится если выравнивание на 4 бита
20+20+10(+2 выравнивания)+4=56
хотя я привожу расчеты по опыту работы с микрософт а как Борланд выравнивает не знаю
Lers
12 / 12 / 3
Регистрация: 27.05.2012
Сообщений: 202
16.01.2014, 20:53  [ТС]     Как происходит процесс выделения памяти в стеке и куче #32
Всем большое спасибо за помощь! С выравниванием большое спасибо, разобрался, а про борланд сам поищу, может найду правду!
alsav22
5284 / 4803 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
16.01.2014, 20:59     Как происходит процесс выделения памяти в стеке и куче #33
Цитата Сообщение от Lers Посмотреть сообщение
С выравниванием большое спасибо, разобрался, а про борланд сам поищу, может найду правду!
Там же есть выравнивание по байту (на скрине видно), или тут теоретические вопросы выравнивания выясняются?
Lers
12 / 12 / 3
Регистрация: 27.05.2012
Сообщений: 202
16.01.2014, 21:20  [ТС]     Как происходит процесс выделения памяти в стеке и куче #34
Цитата Сообщение от alsav22 Посмотреть сообщение
Там же есть выравнивание по байту (на скрине видно), или тут теоретические вопросы выравнивания выясняются?
да не было конкретной вопроса, выравнивание по байту - оно не будет увеличивать размер, я так понимаю?
затестил с выравниванием по байту, действительно не увеличивает размер
C++
1
2
3
4
5
6
7
8
class Disc
{
  public:
  char namedisc[20];
  char teacher_name[20];
  char name_group[10];
  int hours;
};
20+20+10+4=54 байта.
alsav22
5284 / 4803 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
16.01.2014, 21:22     Как происходит процесс выделения памяти в стеке и куче #35
Цитата Сообщение от Lers Посмотреть сообщение
выравнивание по байту - оно не будет увеличивать размер
...
Lers
12 / 12 / 3
Регистрация: 27.05.2012
Сообщений: 202
16.01.2014, 21:24  [ТС]     Как происходит процесс выделения памяти в стеке и куче #36
Цитата Сообщение от alsav22 Посмотреть сообщение
...
ну я имею ввиду конкретно мой пример
alsav22
5284 / 4803 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
16.01.2014, 21:56     Как происходит процесс выделения памяти в стеке и куче #37
Цитата Сообщение от Lers Посмотреть сообщение
ну я имею ввиду конкретно мой пример
Имеете ввиду, что sizeof() выдаст? При выравнивании по байту, выдаст сумму размеров полей.
ValeryS
Модератор
6403 / 4869 / 447
Регистрация: 14.02.2011
Сообщений: 16,159
16.01.2014, 22:00     Как происходит процесс выделения памяти в стеке и куче #38
Цитата Сообщение от alsav22 Посмотреть сообщение
если объекты в куче, то sizeof() нужно не к указателям применять.
а к чему
указатель то хоть размер указателя даст
а размер объекта кто?
придется размер структуры( класса) высчитывать
sizeof (Disc)
а сколько памяти под этот объект выделится одному менеджеру известно

Добавлено через 1 минуту
Lers,
введи код который я привел и увидишь как в зависимости от выравнивания будут размещаться поля
alsav22
5284 / 4803 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
16.01.2014, 22:08     Как происходит процесс выделения памяти в стеке и куче #39
Цитата Сообщение от ValeryS Посмотреть сообщение
а к чему
указатель то хоть размер указателя даст
а размер объекта кто?
А так размер объекта не даст?
C++
1
sizeof(*d3);
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
16.01.2014, 22:11     Как происходит процесс выделения памяти в стеке и куче
Еще ссылки по теме:

Динамическое выделение памяти. Ошибки в куче C++
C++ Как выделяется память на стеке и на куче? Когда нужна ручная очистка?
Как написать программу для динамического выделения памяти с использованием new C++
C++ Нужно ли удалять указатель на символьный массив созданный в куче(динамически распределяемой памяти)
C++ Динамическое выделения памяти

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

Или воспользуйтесь поиском по форуму:
ValeryS
Модератор
6403 / 4869 / 447
Регистрация: 14.02.2011
Сообщений: 16,159
16.01.2014, 22:11     Как происходит процесс выделения памяти в стеке и куче #40
Цитата Сообщение от alsav22 Посмотреть сообщение
А так размер объекта не даст?
попробуй
у меня сейчас нет компилятора под рукой
но помню что пытался считать размер массива ничего не получилось, приходилось запоминать
с объектами может быть тоже самое, а может и нет
Yandex
Объявления
16.01.2014, 22:11     Как происходит процесс выделения памяти в стеке и куче
Ответ Создать тему
Опции темы

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