Герберт Шилдт - C# 4.0 полное руководство - 2011
- Название:C# 4.0 полное руководство - 2011
- Автор:
- Жанр:
- Издательство:неизвестно
- Год:неизвестен
- ISBN:нет данных
- Рейтинг:
- Избранное:Добавить в избранное
-
Отзывы:
-
Ваша оценка:
Герберт Шилдт - C# 4.0 полное руководство - 2011 краткое содержание
C# 4.0 полное руководство - 2011 - читать онлайн бесплатно полную версию (весь текст целиком)
Интервал:
Закладка:
Считывает значение типа double
float ReadSingleO
Считывает значение типа float
short Readlntl6()
Считывает значение типа short
int Readlnt32()
Считывает значение типа int
long Readlnt64()
Считывает значение типа long
ushort ReadUIntl6()
Считывает значение типа ushort
uint ReadUInt32()
Считывает значение типа uint
ulong ReadUInt64()
Считывает значение типа ulong
string ReadStringO
Считывает значение типа string,представленное во внутреннем двоичном формате с указанием длины строки. Этот метод следует использовать для считывания строки, которая была записана средствами класса BinaryWriter
В классе BinaryWriter определены также три приведенных ниже варианта метода Read ().
При неудачном исходе операции чтения эти методы генерируют исключение 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 удается открыть файл " +
"товарных запасов для ввода");
Интервал:
Закладка: