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

Не записываются данные в бинарный файл - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Циклическая очередь, сбой после удаления/добавления элемента http://www.cyberforum.ru/cpp-beginners/thread810867.html
нарушается после того как удаляю элемент, и добавляю элемент снова Организуйте циклическую очередь для хранения целых чисел. Для очереди используйте массив указателей на структуры. Продемонстрируйте добавление элемента, удаление элемента, добавление в переполненную очередь, удаление из пустой очереди. После каждого примера вывести содержимое очереди.#include <string.h> #include <stdlib.h>...
C++ перегрузка [] Здарова никак не могу перегрузить имеется класс Int2 моделирующий int я перегрузил rvalue тоесть при вызове int a; Int2 b(5,4);//5 элементов, знач 4 a=b; cout <<a; //4 http://www.cyberforum.ru/cpp-beginners/thread810842.html
Кодер Хемминга C++
Нашёл в интернете кодер Хемминга, но при запуске выдаёт ошибку о том, что переменная otv была использована до её объявления. Сам в коде разобраться пока не смог. Помогите исправить код, чтобы он работал и если вас не затруднит, то ещё немного комментариев по коду написать для понятности. #include <conio.h> #include <stdio.h> int barr; int barr_cod; int coding1() {
dev c++ max stack size C++
подскажите где в dev c++ можно выставить размер стэка,стандартного 1 мб маловато мне 3 необходимо
C++ программирование рекурсивных алгоритмов http://www.cyberforum.ru/cpp-beginners/thread810820.html
Подсчитать, сколькими способами можно расставить k двоек в n- мерном троичном векторе (0\leq k\leq n). Вывести все возможные варианты.
C++ Неизвестная конструкция Задача поставлена так: Написать программу, переводящую арабские числа в римские. Задача упрощается тем, что можна считать, что 40=XXXX, 9=VIIII и тому подобное. Саму программу я написал, но меня волнует проверка на ввод. Я ее где-то выкопал и не знаю, как она работает. #include <iostream> #include <conio.h> #include <stdio.h> using namespace std; int roman(int i, int j, char k) {... подробнее

Показать сообщение отдельно
Enot52
0 / 0 / 0
Регистрация: 17.03.2013
Сообщений: 7
17.03.2013, 14:16  [ТС]     Не записываются данные в бинарный файл
Цитата Сообщение от alsav22 Посмотреть сообщение
Давайте весь код. В самой функции записи я ошибок не вижу.
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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
// Seminar1.cpp: определяет точку входа для консольного приложения.
//
 
 
 
#include "stdio.h"
#include <time.h>
#include <iostream>
#include <locale.h>
#include <fstream>
 
using namespace std;
 
int menu_select(void);
 
FILE *fd;
 
 
// Список
class List{
   class Element{                     
   private: 
      int *data; // элемент многочлена
   public: 
      Element *next; // следующий элемент
      Element *prev; // предыдущий
      Element():next(NULL),prev(NULL){data=new int(0);}; // конструктор по-умолчанию
      Element(int val):next(NULL),prev(NULL){data=new int(val);}; // перегруженный конструктор
      Element (Element &e)      // конструктор копирования
      {
         data=new int(e.getData());
         next=e.next;
         prev=e.prev;
      }
      ~Element(){if (data) delete data;next=prev=NULL;}  // деструктор
 
      int getData(){return *data;}  // метод для получения
      void setData(int val){*data=val;} // и установки данных
   };
   public: 
   Element *first; // первый элемент
   Element *last; // последний
   List():first(NULL),last(NULL){} 
   ~List() // деструктор списка
   {
      Element *p=last;
      while(p)
      {
         Element *pt=p;
         p=p->prev;  
         delete pt; // удаление элементов с конца
      }
      first=last=NULL; // и указателей
   } 
 
   // добавление в конец списка
   void Add(int val) 
   {
      Element *t=new Element(val); // создать новый элемент с содержимым val
      if(first==NULL)   // если элементов нет
      {
         first=last=t; // то он первый и последний
         first->next=last->next=NULL; 
         first->prev=last->prev=NULL;
         return; 
      }
      // если есть элементы
      last->next=t; // добавляем после последнего
      t->prev=last; // бывший последний теперь предпоследний
      last=t; // последний - новый элемент
      last->next=NULL;
   }
 
   // удаление элемента
   void Delete(int n)  
   {
      // поиск ненужного элемента
      Element *i = first;
      int k=0;
      while (i && k<n)
      {
         i = i->next;
         k++;
      }
      if (i) // если найден
      {
         if (i==first) // если это первый элемент 
         {
            Element *t = new Element(*first); 
            first=first->next; 
            first->prev=NULL; 
            delete t;
            return;
         }
         // если это последний элемент
         if (i==last)
         {
            Element *t = new Element(*last);
            last=last->prev;
            last->next=NULL;
            delete t;
            return;
         }
         // если обычный
         i->prev->next=i->next; 
         i->next->prev=i->prev;
         delete i; 
      }
   }
   
   // вывод многочлена
   void Print(int dir) // направление: dir == 0 --->>> | dir == 1 <<<---
   {
      Element *i;
      dir ? i = last: i = first; // решаем откуда будем начинать
      while (i) // пока есть элементы
      {
         cout << "\n" << i->getData(); // выводим данные
         if (dir)
            i=i->prev; // в направлении <<<--- 
         else           // или
            i=i->next; // в направлении --->>> 
      }
   }
 
   void Result()
   {
       int a=0;    
       Element *i=first;
       while (i)   //  Если есть элементы
       {
           a=a+i->getData();  // то прибавить их к a
           i=i->next;   // перейти к следующему
       }
       cout << "Результат: \n" << a;
   }
 
   void operator+(List &e) 
   {
       
       Element *i=e.first;
      while (i) // и пока есть смысл...
      {
         Add(i->getData()); // ...добавляем данные
            i=i->next; // в направлении --->>> туда
      }
   }
 
   void operator-(List &e) 
   {
       
       Element *i=e.first;
      while (i) // и пока есть смысл...
      {
         Add(-(i->getData())); // ...добавляем данные
            i=i->next; // в направлении --->>> туда
      }
   }
 
   void operator++()
   {
        Element *i;
      i = first; // решаем откуда будем начинать (см. dir)
      while (i) // и пока есть смысл...
      {
          int v=i->getData();
          v++;
          i->setData(v);
          i=i->next; // в направлении --->>> туда
      }
     }
 
 
   // Загрузка многочлена из текстового файла
   void LoadText()
   {
       int h;
       char g[64];
       char line[64]; 
       Element *i=first;
       ifstream file_object("textfile.txt"); 
        while(! file_object.eof())
       {
           file_object.getline(line, sizeof(line));
           cout << line << endl; 
           h=atoi(line);
           Add(h);
 
           
       }
   }
 
   // сохранение многочлена в файл
   void SaveText()
   {
       int h;
       char g[64];
       Element *i=first;
       ofstream file_object("textfile.txt", ios::out); 
        while(i)
       {
           h=i->getData();
           itoa(h, g, 10);
           file_object << g << endl;
           i=i->next; 
       }
 
 
   }
 
    // Загрузка многочлена из двоичного файла
   void LoadBin()
   {
       return;
   }
 
   void SaveBin()
   {
       if ((fd=fopen("file.dat", "wb"))==NULL) return;  //Открыть файл
       int g;
       Element *i=first;
       while(i)    //Пока есть значения
       {
        g=i->getData();         //Получение значения элемента списка
        i=i->next;              //перейти к следующему
        cout << g << endl;
        fwrite(&g, sizeof(int), 1, fd);    //Записать элемент в файл
       }
   }
   };
  
 
 
 
   void main ()
{
 
 
    setlocale(LC_ALL, "Russian");   
List a;     // Создание объекта
int val=0;
 
// Выбор пункта меню.
for (;;)
{
switch (menu_select())
{
case 1: a.Print(0);
break;
case 2: { cout << "Введите число: \n"; cin >> val; a.Add(val); }
break; 
case 3: a.Result();
break;
case 4: { cout << "Введите номер удаляемого числа: \n"; cin >> val; a.Delete(val);}
break;
case 5: a.SaveText();
break;
case 6: a.LoadText();
break;
case 7: a.SaveBin();
break;
case 8: exit(0);
}}
 
getchar(); 
}
 
      // Меню
int menu_select(void)
{
int c;
 
cout << "\n1. Вывод всех элементов на экран\n";
cout << "2. Добавление нового элемента\n";
cout << "3. Вычисление результата\n";
cout << "4. Удаление элемента\n";
cout << "5. Сохранение многочлена в текстовый файл\n";
cout << "6. Загрузка многочлена из текстового файла\n";
cout << "7. Сохранение многочлена в двоичный файл (ошибка)\n";
 
cout << "8. Выход\n";
do {
cout << "\nВведите номер нужного пункта: \n";
cin >> c;
} while(c<0 || c>7);
return c;
}
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru