The dynamic array of structures we analyze the example. We need to solve the following task: the user enters data about the sponsors of the project. Namely – surname, name and donation amount. After each data input program asked: continue typing or not.
Every time, when the user selects “continue” – It is necessary to allocate a piece of memory under one structure. Thus a dynamic array of structures will grow, until the user suspends entry. When you have finished entering, display a table with information about the sponsors on the screen.
| 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 | #include<iostream> #include<windows.h>  using namespace std; struct Sponsor {  char name[32];  char surname[32];  double sum; }; Sponsor* AddStruct(Sponsor* Obj, const int amount); void setData(Sponsor* Obj, const int amount); void showData(const Sponsor* Obj, const int amount); int main() {  setlocale(LC_ALL, "rus");  Sponsor* OurSponsors = 0;  int sponsorAmount = 0;  int YesOrNot = 0; //  продолжить или остановить ввод данных  do  {  OurSponsors = AddStruct(OurSponsors, sponsorAmount);  setData(OurSponsors, sponsorAmount);  sponsorAmount++;  cout << "Продолжить ввод данных (1 - да, 0 - нет): ";  cin >> YesOrNot;  cin.get();  } while (YesOrNot != 0);  showData(OurSponsors, sponsorAmount);  delete[] OurSponsors;  return 0; } Sponsor* AddStruct(Sponsor* Obj, const int amount) {  if (amount == 0)  {   Obj = new Sponsor[amount + 1]; // выделение памяти для первой структуры  }  else  {  Sponsor* tempObj = new Sponsor[amount + 1];  for (int i = 0; i < amount; i++)  {  tempObj[i] = Obj[i]; // копируем во временный объект  }  delete [] Obj;  Obj = tempObj;   }   return Obj; } //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ void setData(Sponsor* Obj, const int amount) {  cout << "Фамилия: ";  cin.getline(Obj[amount].surname, 32);  cout << "Имя: ";  cin.getline(Obj[amount].name, 32);  cout << "Сумма пожертвования: ";  cin >> Obj[amount].sum;  cin.get();   cout << endl;  } //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ void showData(const Sponsor* Obj, const int amount) {  system("cls");  cout << "№  " << "Фамилия\t" << "Имя\t" << "Сумма\t" << endl;  cout << "========================================" << endl;  for (int i = 0; i < amount; i++)  {   cout << i + 1 << "  " << Obj[i].surname << '\t' << Obj[i].name << '\t' << Obj[i].sum << endl;  } } | 
Determination of the structure is in srtrings 5 – 10. It announced three elements name, surname, sum. Below the declared function prototypes, necessary to solve the task. The first function Sponsor* AddStruct(Sponsor* Obj, const int amount); will allocate memory for the elements of an array of structures. Second void setData(Sponsor* Obj, const int amount); is responsible for entering data into a structure. The third void showData(const Sponsor* Obj, const int amount); – It displays all the data in a table. Definitions of these functions will be discussed below.
To create a dynamic array of structures, must, as to create the usual dynamic array, declare a pointer. Only instead of a built-in type specify the descriptor structure – string 20. This pointer is nothing on points. It would be possible to allocate memory for an array of structures at once. For example:
But we will organize a more flexible allocation of memory for the dynamic array of structures – it will be allocated as needed. There is one sponsor – selects the memory under one structure. There are 3 sponsors – memory is allocated first under one structure, then under the second and further under the third. Everything will depend on – decides whether the user continue typing.
In strings 21 – 22, declared variables sponsorAmount – count the number of sponsors and YesOrNot – user selection (continue or interrupt input).
Strings 24 – 34: here is the loop do while. It runs until, until the user needs to enter data. In string 26 call function, which allocates memory for the structure OurSponsors = AddStruct(OurSponsors, sponsorAmount); Descend to its definition in the srtrings 42 – 61. Here it can be seen, that this function will return a pointer to a structure Sponsor.
It takes two parameters – a pointer to the structure and number of structures. When it is called for the first time – it will send an announcement in main pointer OurSponsors and variable sponsorAmount, which is zero. In the function block is executed if – selects the memory for a structure (strings 44 – 47). Then the function will return an address (pointer) this memory section and it will be recorded in OurSponsors – string 26.
In string 27 call function, which will allow to make a data structure. Its definition is in srtrings 63 – 73. After entering data, variable sponsorAmount is incremented. User offer make a choice – continue to enter or exit the. If we continue to – again, the function is called AddStruct().
It must be remembered, that pointer OurSponsors already refers to the memory location with recorded data. So do not just get reisolated memory. First, you need to take care about saving data. Look at the block else strings 48 – 59. In string 50 create a temporary pointer. Under it allocate memory for amount + 1 structures (i.e.. more than one structure, what took function). Next, copy the data from the received object.
Last object array structures tempObj left blank. When data is copied, frees memory Obj – string 57 and write in the new address pointer. He will point to memory, in which there are stored data and the additional allocated memory area for filling new data.
Once again, the function is called setData(), which will allow to make the data in a new dedicated section of storage – in the last element of the array of structures.
When a user decides to no longer enter data – He presses the zero. After this, work function showData() and the screen will display a table with the data from all the structures of dynamic array. At the end of the program do not forget to free memory, which takes a dynamic array of structures.
Result – data input:
Table:



int YesOrNot = 1;
Why not remove addstruct tempObj if at the end of all the values have already been transferred to the Obj?
+1 whether the memory is freed, allocated for the variable after the function tempObj?
A, excuse me, we are in a allocated for tempObj memory now stores an array!
All, that you select in the program through the new operator, will not be deleted automatically, All these objects are allocated in a separate program “dog” memory, and you obliged to to remove them manually, delete operator, after, how they will eliminate the need.
In this particular example tempObj – this is at the beginning of the pointer placing the array, you assign it to the same index Obj (who returned from the function AddStruct), tempObj pointer and the value itself is destroyed at the point of completion function AddStruct.
Why in 46 the line allocates memory amount + 1??? It is possible, please specific explanation??
1u6bqc
GEF2B