| Член | Описание |
|---|---|
| BaseStream | Свойство, доступное только для чтения. Обеспечивает доступ к потоку, используемому с объемом BinaryWriter |
| Close() | Метод, завершающий двоичный поток |
| Flush() | Метод, выполняющий очистку двоичного потока |
| Seek() | Метод, устанавливающий указатель позиции в текущем потоке |
| Write() | Метод, записывающий значение в текущий поток |
Класс BinaryReader дополняет функциональные возможности, предлагаемые членами BinaryWriter (табл. 16.10).
Таблица 16.10. Основные Члены BinaryReader
| Член | Описание |
|---|---|
| BaseStream | Свойство, доступное только для чтения. Обеспечивает доступ к потоку, используемому с объектом BinaryReader |
| Close() | Метод, завершающий двоичный поток чтения |
| PeekChar() | Метод, возвращающий следующий доступный символ без фактического смещения указателя позиции в потоке |
| Read() | Метод, считывающий заданное множество байтов или символов и запоминающий их во входном массиве |
| ReadXXX() | Класс BinaryReader определяет множество методов ReadXXX(), "захватывающих" следующий тип из потока (ReadBoolean(), ReadByte(), ReadInt32() и т.д.) |
В следующем примере в новый файл *.dat записывается целый ряд типов данных,
static void Main(string[] args) {
// Открытие сеанса двоичной записи в файл.
FileInfo f = new FileInfo("BinFile.dat");
BinaryWriter bw = new BinaryWriter(f.OpenWrite());
// Печать информации о типе BaseStream.
// (в данном случае это System.IO.FileStream) .
Console.WriteLine("Базовый поток: {0}", bv.BaseStream);
// Создание порции данных для сохранения в файле.
double aDouble = 1234.67;
int anInt = 34567;
char[] aCharArray = {
// Запись данных.
bw.Write(aDouble);
bw.Write(anInt);
bw.Write(aCharArray);
bw.Close();
}
Обратите внимание на то, что объект FileStream, возвращенный из FileInfo.OpenWrite(), передается конструктору типа BinaryWriter. С помощью такого подхода очень просто выполнить "расслоение" потока перед записью данных. Следует осознавать, что конструктор BinaryWriter способен принять любой тип, производный от Stream (например, FileStream, MemoryStream или BufferedStream). Поэтому, если нужно записать двоичные данные, например, в память, просто укажите подходящий объект MemoryStream.
Для чтения данных из файла BinFile.dat тип BinaryReader предлагает множество опций. Ниже мы используем PeekChar(), чтобы выяснить, имеет ли поток еще данные, и в том случае, когда он их имеет, использовать ReadByte() для получения значения. Обратите внимание на то, что байты форматируются в шестнадцатиричном виде и между ними вставляются семь пробелов.
static void Main(string[] args) {
// Открытие сеанса двоичной записи в файл.
FileInfo f = new FileInfo("BinFile.dat");
…
// Чтение данных в виде "сырых" байтов.
BinaryReader br = new BinaryReader(f.OpenRead());
int temp = 0;
while (br.PeekChar() != -1) {
Console.Write("{0,7:x}", br.ReadByte());
if (++temp == 4) {
// Запись каждых 4 байтов в виде новой строки.
Console.WriteLine();
temp = 0;
}
Console.WriteLine();
}
}
Исходный код. Проект BinaryWriterReader размещен в подкаталоге, соответствующем главе 16.
Вывод этой программы показан на рис. 16.9.
Рис. 16.9. Чтение байтов из двоичного файла
Программный мониторинг файлов