Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
 Аватар для Dostik
38 / 38 / 4
Регистрация: 31.05.2011
Сообщений: 580

Бинарное чтение\ запись

08.08.2013, 18:28. Показов 1003. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем добрый вечер, ребята кто умеет и сталкивался с бинарным чтением и записью помогите отладить бинарную запись этой программы я там начал взял, чужой код но от незнания наваротил что зря ...... так и не понял что там произошло, если кому не трудно отредактируйте с коментариями, заранее огромное спасибо

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
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
Tmain_form      *main_form;
 
HANDLE          COMThread; // дескриптор главного потока, опрашивающего приборы
//===========================================================================
 
HANDLE fmtm_re ;
_SECURITY_ATTRIBUTES temp_mtm,Attr_val_or;
unsigned long l_ser_or,l_val_or;
 
 
 
//===========================================================================
int        __fastcall
Tmain_form::FormCreate(AnsiString &fmtm_re,AnsiString temp_mtm,
              int viRegime,int viSeek,int viNumber,int viType)
{
 HFILE       hFile;
 AnsiString  fmtm_re=temp_mtm+"\\"+fmtm_re;
 DWORD       dwCounter;
 OFSTRUCT    tOfStr;
 tOfStr.cBytes = sizeof tOfStr;
 // Открыть файл
 hFile = OpenFile(vasFileName.c_str(),&tOfStr,OF_READWRITE);
 if(hFile == HFILE_ERROR)
 {
  CloseHandle(HANDLE(hFile));
  //Сообщение об ошибке
  return 1;
 }
 BY_HANDLE_FILE_INFORMATION bhFileInformation;
 GetFileInformationByHandle
 (
  HANDLE(hFile), // Дескриптор файла
  // Адрес структуры, в которой сохраняется информация
  &bhFileInformation
 );
 viRazmer=bhFileInformation.nFileSizeLow;
 //сдвинуться
 switch(viType)
 {
  case 0:
   if(_llseek(hFile,viSeek*sizeof(int),0) != (long)(viSeek*sizeof(int)))
   {
    CloseHandle(HANDLE(hFile));
    //Сообщение об ошибке
   return 1;
   }
   break;
  case 1:
   if(_llseek(hFile,viSeek*sizeof(char),0) != (long)(viSeek*sizeof(char)))
   {
    CloseHandle(HANDLE(hFile));
    //Сообщение об ошибке
   return 1;
   }
  break;
 }
 // считать (записать)данные из (в) файл
 switch(viRegime)
 {
  case 1:
   if(viType == 0)
   {
    if(!WriteFile(HANDLE(hFile),virgRDWRBuff,
                  (DWORD)(viNumber*sizeof(int)),&dwCounter,0))
    {
     //Сообщение об ошибке
     CloseHandle(HANDLE(hFile));
    return 1;
    }
   }else
   {
    if(!WriteFile(HANDLE(hFile),(char far*) vchrgRDWRBuf,
               (DWORD)(viNumber*sizeof(char)),&dwCounter,0))
    {
     //Сообщение об ошибке
     CloseHandle(HANDLE(hFile));
     return 1;
    }
   }//if(viType == 0)
  break;
  case 0:
   if(viType == 0)
   {
    if(!ReadFile(HANDLE(hFile),virgRDWRBuff,
                (DWORD)(viNumber*sizeof(int)),&dwCounter,0))
    {
     //Сообщение об ошибке
     CloseHandle(HANDLE(hFile));
     return 1;
    }
   }else
   {
    if(!ReadFile(HANDLE(hFile),(char far*) vchrgRDWRBuf,
               (DWORD)(viNumber*sizeof(char)),&dwCounter,0))
    {
     //Сообщение об ошибке
     CloseHandle(HANDLE(hFile));
     return 1;
    }
   }//if(viType == 0)
  break;
 }//switch(viRegime)
 CloseHandle(HANDLE(hFile));
return 0;
}           /**/
 
//===========================================================================
//===========================================================================
//---------------------------------------------------------------------------
static const int BaudRate[] =
{
    CBR_110,     CBR_300,    CBR_600,    CBR_1200,    CBR_2400,    CBR_4800,
    CBR_9600,    CBR_14400,  CBR_19200,  CBR_38400,   CBR_56000,   CBR_57600,
    CBR_115200,  CBR_128000, CBR_256000
};
// Имена используемых портов:
//#define COM_Name(i) "COM"##i
static const char* COM_Name[] = {"COM3", "COM4", "COM5", "COM6"};
 
//-------------------------- ГЛОБАЛЬНЫЕ -------------------------------------
modbus_connection    connection; //
//int                  idx;        //
float                idx = 0.0f;
DWORD                dwThreadId, dwThrdParam = 1;
unsigned int         last_msec;   // время предыдущего опроса в мс от заспуска ОС
unsigned int         curr_msec;   // текущее время в мс от запуска ОС
float                data[4][13][5];
/** массив data[порт][прибор][канал] читамых данных
[порт]......0->COM3, 1->COM4, 2->COM5, 3->COM6;
[прибор]....1->MTM1, 2->MTM3, 4-12->НЕ_ИСП., 13->MTM13;
[канал].....0->0x130->1й_канал, 1->0х132->2й канал, ..., 5->0x13A->6й канал  **/
//com_port             port;        //
com_port             COM[4];      // массив портов
//---------------------------------------------------------------------------
#define MTM1         1
#define MTM2         2
#define MTM3         3
#define MTM4         4
#define MTM13       13
// #define MTM*** 0 // добвавить!
// register type:
#define REG0        0x130
#define REG1        0x132
#define REG2        0x134
#define REG3        0x136
#define REG4        0x138
#define REG5        0x13A
const int REG[] = {REG0, REG1, REG2, REG3, REG4, REG5};
// addres type:
#define HOLD_REG    0
#define IN_REEG     1
#define DI_REG      2
#define DO_REG      3
// data type:
#define DATA_INT    0
#define DATA_UINT   1
#define DATA_LONG   2
#define DATA_ULONG  3
#define DATA_FLOAT  4
#define DATA_DOUBLE 5
//---------------------------------------------------------------------------
#define PERIOD      1000 // период опроса датчиков в мс
#define WORK_COLOR  (TColor)0x008F00
#define DENY_COLOR  (TColor)0x0000D0
//---------------------------------------------------------------------------
/**/
#define Status(c,s) { \
    main_form->warnings->Font->Color = c; \
    main_form->warnings->Caption     = s; \
}
 
#define CHART_T main_form->chart_temp
#define CHART_L main_form->chart_level
 
#define SwitchSource(a, r) \
    connection.slave_address    = a; \
    connection.register_address = r;
 
//---------------------------------------------------------------------------
float GetData(com_port* prt, int addr, int reg, int serie)
{
    // переключение на <addr> прибор, <reg> регистр
    SwitchSource(addr, reg);
    //connection.slave_address    = addr;
    //connection.register_address = reg;
    // ожидание готовности порта (В СЛУЧАЕ ОТСУТСВИЯ ЦИКЛ БЕСКОНЕЧЕН!):
    while (!connection.get_sync(prt)) { Sleep(10); }
    // чтение данных из порта:
    return connection.get_raw_value(); // serie = 0...5
}
//---------------------------------------------------------------------------
void MAIN_LOOP ()
{
    while (!Application->Terminated) {
        //curr_msec = GetTickCount();
        // для редактирования компонентов не из основного потока:
        CHART_T->Locked = true; CHART_L->Locked = true;
        // опрос каналов с выводом в TChart (ДОБАВИТЬ ОПРОС ВСЕХ ПОРТОВ!!!):
        /***** ОПРОС 1го ДАТЧИКА: *****
        for (int regN=0; regN<6; regN++) {
            data[regN] = GetData(&COM[0], MTM1, REG[regN], regN); // взять данные с i-го канала
            CHART_T->Series[regN]->AddXY(idx, data[regN]); // вывод в форму
        } // for addrN
        /***** ОПРОС 2го ДАТЧИКА: *****/
        data[1][13][0] = GetData(&COM[1], MTM13, REG[0], 0); CHART_T->Series[0]->AddXY(idx, data[1][13][0],Time()); // ТЕМПЕРАТУРА эмульсии
        data[1][13][1] = GetData(&COM[1], MTM13, REG[1], 1); CHART_T->Series[1]->AddXY(idx, data[1][13][1],Time()); // ДАВЛЕНИЕ густой смазки
        data[1][13][2] = GetData(&COM[1], MTM13, REG[2], 1); CHART_L->Series[1]->AddXY(idx, data[1][13][2],Time()); // УРОВЕНЬ эмульсии в баке 1
        data[1][13][3] = GetData(&COM[1], MTM13, REG[3], 0); CHART_L->Series[0]->AddXY(idx, data[1][13][3],Time()); // УРОВЕНЬ эмульсии в баке 2
        data[1][13][5] = GetData(&COM[1], MTM13, REG[5], 0); CHART_T->Series[5]->AddXY(idx, data[1][13][5],Time()); // ТЕМПЕРАТУРА в пирометрической
 
        /**/
        // для редактирования компонентов не из основного потока:
        CHART_T->Locked = false; CHART_L->Locked = false;
        //Status(WORK_COLOR, "Связь: устройство готово");
        Sleep(PERIOD); // задержка размером в период опроса
        idx += PERIOD/1000.0; // ПЕРЕСЧИТАТЬ РЕАЛЬНОЕ ВРЕМЯ ДЛЯ ГРАФИКА!!!
 
 
//---------------------------------------------------------------------------
 
 
 
 
 /**  **/
    }
 
 
 
 
    // while !terminated
} // MAIN_LOOP /**/
//---------------------------------------------------------------------------
void Set_COM_props(com_port* port,    // адрес переменной с настройками порта
                   std::string _name     = "COM3",
                   const int   _BaudRate = CBR_9600,
                   int         _Parity   = 0,
                   int         _ByteSize = 8,
                   int         _StopBits = 0)
{
    port->system_name           = _name;
    port->dcb.DCBlength         = sizeof(port->dcb);
    port->dcb.BaudRate          = _BaudRate;
    port->dcb.fBinary           = true;
    port->dcb.fParity           = _Parity;
    port->dcb.fOutxCtsFlow      = false;
    port->dcb.fOutxDsrFlow      = false;
    port->dcb.fDtrControl       = DTR_CONTROL_DISABLE;
    port->dcb.fDsrSensitivity   = false;
    port->dcb.fTXContinueOnXoff = false;
    port->dcb.fOutX             = false;
    port->dcb.fInX              = false;
    port->dcb.fErrorChar        = false;
    port->dcb.fNull             = false;
    port->dcb.fRtsControl       = RTS_CONTROL_DISABLE;
    port->dcb.fAbortOnError     = false;
    port->dcb.ByteSize          = _ByteSize;
    port->dcb.Parity            = _Parity; // ????
    port->dcb.StopBits          = _StopBits;
    port->dcb.XonChar           = '\x11';
    port->dcb.XoffChar          = '\x13';
    port->dcb.ErrorChar         = '\x00';
    port->dcb.EofChar           = '\x00';
    port->dcb.EvtChar           = '\x00';
}
//---------------------------------------------------------------------------
#define COM_Name(i) ("COM"+IntToStr(i+3)).c_str()
//---------------------------------------------------------------------------
__fastcall Tmain_form::Tmain_form(TComponent* Owner) : TForm(Owner)
{
    // настройка регистра и типа передаваемых данных
    connection.address_type = HOLD_REG;
    connection.data_type    = DATA_FLOAT;
    // инициализация и открытие портов:
    for (int i=0; i<4; i++) { // проверить генерацию имени портов !!!
        Set_COM_props(&COM[i], COM_Name(i), CBR_9600, 0, 8, 0);
        COM[i].open();
        if (!COM[i].active())
            Application->MessageBox(("Ошибка открытия порта " + COM[i].system_name).c_str(), "Ошибка");
   } // for
    /**/
}
//---------------------------------------------------------------------------
void __fastcall Tmain_form::FormClose(TObject *Sender, TCloseAction &Action)
{
    CloseHandle(COMThread);
    for (int i=0; i<4; i++)
        COM[i].close();
    //port.close();
}
//---------------------------------------------------------------------------
void __fastcall Tmain_form::FormCreate(TObject *Sender)
{
    // настройка источника данных:
    SwitchSource(MTM1, REG1);
    connection.address_type = HOLD_REG;
    connection.data_type    = DATA_FLOAT;
    // создание потока:
    COMThread = CreateThread(  //BeginThread(
        NULL,                              // default security attributes
        0,                                 // use default stack size
        (LPTHREAD_START_ROUTINE)MAIN_LOOP, // thread function
        &dwThrdParam,                      // argument to thread function
        0,                                 // use default creation flags
        &dwThreadId);                      // returns the thread identifier
    //last_msec = GetTickCount();
 
 
} /**/
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
08.08.2013, 18:28
Ответы с готовыми решениями:

Запись и чтение *.ini
Здравствуйте. Вот код записи в *.ini файл: //--------------------------------------------------------------------------- void...

Запись / Чтение из файла
пробовал и TStringStream, и TStringList все равно 1 символ выводит... Сначала я записываю в этот файл хэш сумму sha1 из БД В БД она...

Запись и чтение из файла
В общем, есть код, с помощью которого мы сохраняем полный путь к треку в файл и потом считываем этот путь из файла соответсвенно.. Способы...

4
 Аватар для cpp_developer
20124 / 5691 / 417
Регистрация: 09.04.2010
Сообщений: 22,546
Записей в блоге: 1
08.08.2013, 23:34
обуждалось 100500 раз, с комментариями
1
 Аватар для Dostik
38 / 38 / 4
Регистрация: 31.05.2011
Сообщений: 580
09.08.2013, 11:49  [ТС]
Цитата Сообщение от LK Посмотреть сообщение
обуждалось 100500 раз, с комментариями
Это всё понятно, но у меня есть главный поток опроса портов и т.д, и как мне забрать значения 15 приборов и записать данные в бинарник с рассширение .dat а в другой программе забрать
0
 Аватар для cpp_developer
20124 / 5691 / 417
Регистрация: 09.04.2010
Сообщений: 22,546
Записей в блоге: 1
09.08.2013, 23:48
если другая программа ваша - проблем как бы не должно быть, еcли не ваша - FindWindow() - и в том, и в другом случае можно обойтись без дополнительной прокладки - файла .dat, в который, при желании, можно просто писать протокол (лог).
0
 Аватар для Dostik
38 / 38 / 4
Регистрация: 31.05.2011
Сообщений: 580
12.08.2013, 09:27  [ТС]
Цитата Сообщение от LK Посмотреть сообщение
если другая программа ваша - проблем как бы не должно быть, еcли не ваша - FindWindow() - и в том, и в другом случае можно обойтись без дополнительной прокладки - файла .dat, в который, при желании, можно просто писать протокол (лог).
Программа моя просто вообще в будущем нужно писать все в БД Oracle, уже этот вопрос решается, ну а для себя хотелбы знать как на моём примере будут писаться данные ...... спасибо вам за ответы, и советы!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
12.08.2013, 09:27
Помогаю со студенческими работами здесь

Чтение/Запись в файл
Доброго всем времени суток. При написании курсовика пытаюсь вспомнить навыки С++, но дело идет туго. Необходима программа тестирования...

Чтение/запись из файла
Здравствуйте! Такой вот вопрос: есть файл,который мы читаем, он представляет из себя массив одномерный в виде 10101010100010101010.......

Запись и чтение с файла
Здраствуйте! Есть такая структура: struct Elem {AnsiString Name; int poinyX; int pointY; }; Elem masElem;

Чтение и запись в файл
Помогите пожалуйста))) сижу на контрольной надо решить задачу: Из бинарного файла А записи с номерами, кратными трем, записать в файл...

Запись и чтение из файла C++
Всем привет! У меня есть файл .b (Сохранение для GTA 3). Мне нужно написать простенький редактор сохранений для этой игры, чтобы менять...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
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
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru