Навигация
Главная
Поиск
Форум
FAQ's
Ссылки
Карта сайта
Чат программистов

Статьи
-Delphi
-C/C++
-Turbo Pascal
-Assembler
-Java/JS
-PHP
-Perl
-DHTML
-Prolog
-GPSS
-Сайтостроительство
-CMS: PHP Fusion
-Инвестирование

Файлы
-Для программистов
-Компонеты для Delphi
-Исходники на Delphi
-Исходники на C/C++
-Книги по Delphi
-Книги по С/С++
-Книги по JAVA/JS
-Книги по Basic/VB/.NET
-Книги по PHP/MySQL
-Книги по Assembler
-PHP Fusion MOD'ы
-by Kest
Professional Download System
Реклама
Услуги

Автоматическое добавление статей на сайты на Wordpress, Joomla, DLE
Заказать продвижение сайта
Программа для рисования блок-схем
Инженерный калькулятор онлайн
Таблица сложения онлайн
Популярные статьи
OpenGL и Delphi... 65535
Форум на вашем ... 65535
21 ошибка прогр... 65535
HACK F.A.Q 65535
Бип из системно... 65535
Гостевая книга ... 65535
Invision Power ... 65535
Пример работы с... 65535
Содержание сайт... 65535
ТЕХНОЛОГИИ ДОСТ... 65535
Организация зап... 65535
Вызов хранимых ... 65535
Создание отчето... 65535
Имитационное мо... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Реклама
Сейчас на сайте
Гостей: 10
На сайте нет зарегистрированных пользователей

Пользователей: 13,372
новичок: vausoz
Новости
Реклама
Выполняем курсовые и лабораторные по разным языкам программирования
Подробнее - курсовые и лабораторные на заказ
Delphi, Turbo Pascal, Assembler, C, C++, C#, Visual Basic, Java, GPSS, Prolog, 3D MAX, Компас 3D
Заказать программу для Windows Mobile, Symbian

Моделирование работы аэропорта на GPSS + Пояснительная записка
Моделирование автовокзала + Отчет + Блок схема
Моделирование работы класса персональных компьютеров на GPSS + Отчет + Б...

Копирование и дозапись двоичных файлов
Копирование и дозапись двоичных файлов можно выполнить той же функцией f ilecopyO (см. листинг 14.4), открыв потоки как двоичные, например:
// копирование файлов
{ ifstream instrm ("c:/binfiles/oonumberl.bin", std::ios::binary); ofstream outstrm("c:/binfiles/oonumber.new", std::ios::binary); if (instrm) tJilecopy(instrm, outstrm);
}
// дозапись нового файла в конец старого
{ ifstream instrm ("c:/b1nfiles/oonumber2.binH, std::ios::binary); ofstream outstrm("c:/binfiles/oonumber.new",
std::ios::app|std::ios::binary); if (instrm) filecopy(instrm, outstrm);
}



Как и при обработке текстовых файлов, разница заключается только в режиме открытия.
Напишем программу сравнения двоичных файлов, чтобы убедиться, что файл oonumber2.bin совпадает с исходным файлом oonumberl .bin. Реализуем эту операцию в виде функции сравнения filecompare():
bool filecompare(ifstream &first, ifstream &second);



Параметрами этой функции являются открытые потоки (как в функции file-сору ()), а результат — булево значение, равное:
• true, если файлы идентичны;
• false, если файлы различаются.
Нам достаточно сравнить файлы побайтно, выдав значение false при первом различии:
// функция сравнения файлов побайтно bool filecompare(ifstream &first, ifstream &second) { char chl = 0, ch2; while (chl != EOF)
{ chl = first.get(); ch2 = second.get(); if (chl!=ch2) return false;
}
return true;
}
// в главной программе...
ifstream first ("c:/binfiles/oonumberl.bin", std::ios::binary);
ifstream second("c:/binfiles/oonumber2.bin", std::ios::binary);
if(filecompare(first, second)) cout << "Files are equals!"<< endl;
else cout << "Files are not equals!" << endl;



Если файлы совпадают, программа выводит на экран строку Files are equals!
Между прочим, эта же функция сравнения прекрасно работает с любыми текстовыми файлами, поскольку ввод информации Осуществляется посимвольно.
Ввод-вывод объектов в двоичный файл
До сих пор мы выводили в двоичные файлы объекты только встроенных типов. Теперь настала пора разобраться с проблемами, возникающими в двоичных файлах при вводе-выводе объектов произвольного типа. Как мы уже знаем (см. главу 1), размеры классов и структур в памяти зависят от выравнивания. Рассмотрим тот же вопрос с точки зрения записи в двоичный файл. Напишем простую программу (листинг 14.8), в которой просто выведем в двоичный файл несколько структур в двух режимах: с выравниванием по байту и без.

Листинг 14.8. Размеры объектов на диске
#include <fstream> #include <iostream> using namespace std; //#pragma pack(l) int main()
{
ofstream f; class Empty {}; Empty t;
f.open("c:/binfiles/binempty.bin", if(!f.is_open()) abort(); f.write((char *)&t, sizeof(t)); f .closeO ; struct BinNotPackl { double a; char ch; int b; }; BinNotPackl A = { 1.0, 'a', 1}; cout << sizeof(A) << endl; f.open("с:/binfiles/binA.bin if(!f.is_open()) abort(); f.write((char *)&A, sizeof(A)); f .closeO: struct BinNotPack2 { int b; double a; char ch; }; BinNotPack2 В = { 1, 1.0,'a'}: cout << sizeof(B) << endl; f.open("c:/binfiles/binB.bin", ios: if(!f.is_open()) abort(); f.write((char *)&B, sizeof(B)); f .closeO ; return 0;



// выранивание по байту
// пустой класс ios::binary);
// пишем пустой класс
// неупакованная структура

// размер = 24 :binary);
// пишем структуру В

}



Эта простая программа записывает в наш каталог BinFiles три файла: binempty.bin, binA.bin и binB.bin. В первый файл записывается «пустой» класс, а во второй и третий — специально невыровненные структуры. Как выясняется, на диск записывается точно столько же байтов, сколько структура занимает в памяти. В системе Visual C++.NET 2003 при отсутствии директивы выравнивания размеры переменных Empty t, BinNotPackl А и BinNotPack2 В равны 1,16 и 24 байт соответственно. Ровно столько же места они занимают и на диске — каждая в своем файле. Если же задать директиву выравнивания, то размеры структур станут равными 13:
#pragma pack(l)



Столько же записывается и в файлы.

В системе Borland С++ Builder 6 наблюдается аналогичная картина. При отсутствии выравнивания на диск записывается 8, 16 и 24 байта . При наличии директивы выравнивания на диск записывается столько же байтов, сколько и в системе Visual С++ - 1, 13 и 13.
Опубликовал Kest April 07 2014 14:12:00 · 0 Комментариев · 4238 Прочтений · Для печати

• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •


Комментарии
Нет комментариев.
Добавить комментарий
Имя:



smiley smiley smiley smiley smiley smiley smiley smiley smiley
Запретить смайлики в комментариях

Введите проверочный код:* =
Рейтинги
Рейтинг доступен только для пользователей.

Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.

Нет данных для оценки.
Гость
Имя

Пароль



Вы не зарегистрированны?
Нажмите здесь для регистрации.

Забыли пароль?
Запросите новый здесь.
Поделиться ссылкой
Фолловь меня в Твиттере! • Смотрите канал о путешествияхКак приготовить мидии в тайланде?
Загрузки
Новые загрузки
iChat v.7.0 Final...
iComm v.6.1 - выв...
Visual Studio 200...
CodeGear RAD Stud...
Шаблон для новост...

Случайные загрузки
ИНТЕРНЕТ ПРОГРАММ...
Delphi 2005 для W...
Определние размер...
DelTrayIcon [Исхо...
Синтаксический ан...
TelBook
Assistant
mp3tag
Программирование ...
NotePad Pro [Исхо...
DS_Group
Battle.Net - мони...
Cтатьи Королевств...
Библия хакера 2. ...
Профессиональное ...
ScreenSaver [Исхо...
Цветной Grid
Применение фильтр...
Delphi Russian Kn...
Scrrlcaptoin

Топ загрузок
Приложение Клие... 100774
Delphi 7 Enterp... 97839
Converter AMR<-... 20268
GPSS World Stud... 17014
Borland C++Buil... 14194
Borland Delphi ... 10293
Turbo Pascal fo... 7374
Калькулятор [Ис... 5984
Visual Studio 2... 5207
Microsoft SQL S... 3661
Случайные статьи
Простой дизайн
В этой главеГруппо...
Процедуры и функци...
8.6. Принципы
Процедуры кодирова...
Программирование: ...
Игры. Безопасность...
СТРУКТУРА МОДУЛЯ L...
Классы и IDL
На чем основан поиск
Лайтбоксы и вывеск...
Параметры по умолч...
Подключение Micros...
Смысл разработки и...
Блоки организации ...
Шаблоны и наследов...
Распространение пр...
Фрикинг контроллер...
Транзакции
Прибыльные слоты о...
Игровые автоматы о...
Рик Лемонс как-то ...
Общение в чате
Файл HelloAndroidA...
Строковые потоки
Статистика



Друзья сайта
Программы, игры


Полезно
В какую объединенную сеть входит классовая сеть? Суммирование маршрутов Занимают ли таблицы память маршрутизатора?