Студопедия — Бинарный файл/Двоичный файл
Студопедия Главная Случайная страница Обратная связь

Разделы: Автомобили Астрономия Биология География Дом и сад Другие языки Другое Информатика История Культура Литература Логика Математика Медицина Металлургия Механика Образование Охрана труда Педагогика Политика Право Психология Религия Риторика Социология Спорт Строительство Технология Туризм Физика Философия Финансы Химия Черчение Экология Экономика Электроника

Бинарный файл/Двоичный файл






В бинарных файлов, входных и выходных данных с добычей и вставки операторов (<< and>>) и функций, таких как GetLine не является эффективным, так как нам не нужно форматировать данные, и данные не могут использовать разделение кодов, используемых текстовые файлы на отдельные элементы (например, пространства, новой строки, и т.д...).

 

Файл потоки включают в себя два члена функции, специально предназначенные для ввода и вывода данных двоичной последовательно: write and read. Первый (запись) является членом функция озЬгеат унаследовал ofstream. И чтение является членом функция IStream, который унаследовал геат. Объекты класса fstream оба членов. Их прототипами являются:

File streams include two member functions specifically designed to input and output binary data sequentially: write and read. Первая (write) является членом функции ostream унаследовал ofstream. И read является членом функции istream который унаследовал ifstream. Объекты класса fstream оба членов. Их прототипами являются:

write (memory_block, size);
read (memory_block, size);

Где memory_block имеет тип "указатель на символ" (символ *), и представляет собой адрес массива байт, где читал элементы данных хранятся или от того, где элементы данных должны быть записаны принимаются. Размер параметр является целым числом, которое определяет число символов для чтения или записи из / в memory block.

 

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 // reading a complete binary file #include <iostream> #include <fstream> using namespace std;   ifstream::pos_type size; char * memblock;   int main () { ifstream file ("example.bin", ios::in|ios::binary|ios::ate); if (file.is_open()) { size = file.tellg(); memblock = new char [size]; file.seekg (0, ios::beg); file.read (memblock, size); file.close();   cout << "the complete file content is in memory";   delete[] memblock; } else cout << "Unable to open file"; return 0; } the complete file content is in memory

 

В этом примере весь файл считывается и хранится в блоке памяти. Давайте рассмотрим, как это делается:


Во-первых, файл открыт с ios::ate флаг, который означает, что получить указатель будет располагаться в конце файла. Таким образом, когда мы призываем членов tellg (), мы сразу получаем размер файла. Обратите внимание на тип, который мы использовали, чтобы объявить переменную размера:

 

  ifstream::pos_type size;

 

ifstream::pos_type представляет собой особый тип используется для буфера и позиционирование файла и тип возвращаемого file.tellg (). Этот тип определяется как целое число типа, поэтому мы можем провести на ней те же операции мы проводим на любом другом целое значение, и может быть безопасно преобразован в другой целый тип достаточно большой, чтобы содержать размер файла. Для файла с размером в 2 Гб мы могли бы использовать Int:

 

1 2 int size; size = (int) file.tellg();

 

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

 

  memblock = new char[size];

 

Сразу после этого мы исходим, чтобы установить получить указатель на начало файла (помните, что мы открыли файл с этого указателя в конце), то читать весь файл, и, наконец, закрыть его:

 

1 2 3 file.seekg (0, ios::beg); file.read (memblock, size); file.close();

 

На данном этапе мы могли бы работать с данными, полученными из файла. Наша программа просто объявляет, что содержимое файла в память, а затем прекращается.

 







Дата добавления: 2015-08-12; просмотров: 287. Нарушение авторских прав; Мы поможем в написании вашей работы!



Функция спроса населения на данный товар Функция спроса населения на данный товар: Qd=7-Р. Функция предложения: Qs= -5+2Р,где...

Аальтернативная стоимость. Кривая производственных возможностей В экономике Буридании есть 100 ед. труда с производительностью 4 м ткани или 2 кг мяса...

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

Расчетные и графические задания Равновесный объем - это объем, определяемый равенством спроса и предложения...

СИНТАКСИЧЕСКАЯ РАБОТА В СИСТЕМЕ РАЗВИТИЯ РЕЧИ УЧАЩИХСЯ В языке различаются уровни — уровень слова (лексический), уровень словосочетания и предложения (синтаксический) и уровень Словосочетание в этом смысле может рассматриваться как переходное звено от лексического уровня к синтаксическому...

Плейотропное действие генов. Примеры. Плейотропное действие генов - это зависимость нескольких признаков от одного гена, то есть множественное действие одного гена...

Методика обучения письму и письменной речи на иностранном языке в средней школе. Различают письмо и письменную речь. Письмо – объект овладения графической и орфографической системами иностранного языка для фиксации языкового и речевого материала...

Разновидности сальников для насосов и правильный уход за ними   Сальники, используемые в насосном оборудовании, служат для герметизации пространства образованного кожухом и рабочим валом, выходящим через корпус наружу...

Дренирование желчных протоков Показаниями к дренированию желчных протоков являются декомпрессия на фоне внутрипротоковой гипертензии, интраоперационная холангиография, контроль за динамикой восстановления пассажа желчи в 12-перстную кишку...

Деятельность сестер милосердия общин Красного Креста ярко проявилась в период Тритоны – интервалы, в которых содержится три тона. К тритонам относятся увеличенная кварта (ув.4) и уменьшенная квинта (ум.5). Их можно построить на ступенях натурального и гармонического мажора и минора.  ...

Studopedia.info - Студопедия - 2014-2024 год . (0.01 сек.) русская версия | украинская версия