При неудачном исходе операции чтения эти методы генерируют исключение IOException. Кроме того, в классе BinaryReader определен стандартный метод

Close ().

Метод

Описание

Int

Read()

Возвращает целочисленное представление следующего доступного символа из вызывающего потока ввода. При об

-

наружении конца файла возвращает значение -1

Int

Read(byte [] buffer,

Делает попытку прочитать количество count байтов в

Int

offset, int count)

массив buffer, начиная с элемента buffer[offset ], и возвращает количество успешно считанных байтов

Int

Read(char[] buffer,

Делает попытку прочитать количество count символов

Int

offset, int count)

в массив buffer , начиная с элемента buffer[offset ], и возвоашает количество успешно считанных символов

Демонстрирование двоичного ввода-вывода

Ниже приведен пример программы, в котором демонстрируется применение классов BinaryReader и BinaryWriter для двоичного ввода-вывода. В этой программе в файл записываются и считываются обратно данные самых разных типов.

// Записать двоичные данные, а затем считать их обратно.

Using System; using System.10;

class RWData {

static void Main() {

BinaryWriter dataOut;

BinaryReader dataln;

int i = 10;

double d = 1023.56;

bool b = true;

string str = "Это тест";

// Открыть файл для вывода, try {

dataOut = new

'BinaryWriter(new FileStream("testdata", FileMode.Create));

}

catch(IOException exc) {

Console.WriteLine("Ошибка открытия файла:\п" + exc.Message); return;

}

// Записать данные в файл, try {

Console.WriteLine("Запись " + i) ; dataOut.Write(i);

Console.WriteLine("Запись " + d) ; dataOut.Write(d);

Console.WriteLine("Запись " + b); dataOut.Write(b);

Console.WriteLine("Запись " + 12.2 * 7.4); dataOut.Write(12.2 * 7.4);

Console.WriteLine("Запись " + str); dataOut.Write(str);

}

catch(IOException exc) {

Console.WriteLine("Ошибка ввода-вывода:\n" + exc.Message);

} finally {

DataOut.Close();

}

Console.WriteLine();

//А теперь прочитать данные из файла, try {

dataln = new

BinaryReader(new FileStream("testdata", FileMode.Open));

}

catch(IOException exc) {

Console.WriteLine("Ошибка открытия файла:\п" + exc.Message) return;

}

try {

i = dataln.Readlnt32();

Console.WriteLine("Чтение " + i); d = dataln.ReadDouble();

Console.WriteLine("Чтение " + d); b = dataln.ReadBoolean();

Console.WriteLine("Чтение " + b); d = dataln.ReadDouble();

Console.WriteLine("Чтение " + d); str = dataln.ReadString();

Console.WriteLine("Чтение " + str);

}

catch(IOException exc) {

Console.WriteLine("Ошибка ввода-вывода:\n" + exc.Message);

} finally {

Dataln.Close ();

}

}

}

Вот к какому результату приводит выполнение этой программы.

Запись 10 Запись 1023.56 Запись True Запись 90.28 Запись Это тест

Чтение 10 Чтение 1023.56 Чтение True Чтение 90.28 Чтение Это тест

Если просмотреть содержимое файла testdata, который получается при выполнении этой программы, то можно обнаружить, что он содержит данные в двоичной, а не в удобочитаемой текстовой форме.

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

/* Использовать классы BinaryReader и BinaryWriter для

реализации простой программы учета товарных запасов. */

Using System; using System.10;

class Inventory {

static void Main() {

BinaryWriter dataOut;

BinaryReader dataln;

string item; // наименование предмета

int onhand; // имеющееся в наличии количество

double cost; // цена

try {

dataOut = new

BinaryWriter(new FileStream("inventory.dat", FileMode.Create));

}

catch(IOException exc) {

Console.WriteLine("He удается открыть файл " +

"товарных запасов для вывода");

Console.WriteLine("Причина: " + exc.Message); return;

}

// Записать данные о товарных запасах в файл, try {

dataOut.Write("Молотки"); dataOut.Write(10); dataOut.Write(3.95);

dataOut.Write("Отвертки"); dataOut.Write(18); dataOut.Write(1.50);

dataOut.Write("Плоскогубцы"); dataOut.Write(5);

DataOut.Write (4.95);

dataOut.Write("Пилы"); dataOut.Write (8); dataOut.Write(8.95);

}

catch(IOException exc) {

Console.WriteLine("Ошибка записи в файл товарных запасов");

Console.WriteLine("Причина: " + exc.Message);

} finally {

DataOut.Close();

}

Console.WriteLine() ;

// А теперь открыть файл товарных запасов для чтения, try {

dataln = new

BinaryReader(new FileStream("inventory.dat", FileMode.Open));

}

catch(IOException exc) {

Console.WriteLine("He удается открыть файл " +

"товарных запасов для ввода");

Console.WriteLine("Причина: " + exc.Message); return;

}

// Найти предмет, введенный пользователем.

Console.Write("Введите наименование для поиска: "); string what = Console.ReadLine() ;

Console.WriteLine();

try {

for (;;) {

// Читать данные о предмете хранения, item = dataln.ReadString() ; onhand = dataln.Readlnt32() ; cost = dataln.ReadDouble();

// Проверить, совпадает ли он с запрашиваемым предметом.

// Если совпадает, то отобразить сведения о нем.

if(item.Equals(what, StringComparison.OrdinallgnoreCase)) {

Console.WriteLine(item + ": " + onhand + " штук в наличии. " +

"Цена: {0:С} за штуку", cost);

Console.WriteLine("Общая стоимость по наименованию <{0}>: {1:С}.", item, cost * onhand);

Break;

}

}

}

catch(EndOfStreamException) {

Console.WriteLine("Предмет не найден.");

catch(IOException exc) {

Console.WriteLine("Ошибка чтения из файла товарных запасов");

Console.WriteLine("Причина: " + exc.Message);

} finally {

Dataln.Close();

} '

}

}

Наши рекомендации