Обратите внимание на то, что сведения о товарных запасах сохраняются в этой программе в двоичном формате, а не в удобной для чтения текстовой форме. Благодаря этому обработка числовых данных может выполняться без предварительного их преобразования из текстовой формы.
Обратите также внимание на то, как в этой программе обнаруживается конец файла. Методы двоичного ввода генерируют исключениеEndOf StreamExceptionпо достижении конца потока, и поэтому файл читается до тех пор, пока не будет найден искомый предмет или сгенерировано данное исключение. Таким образом, для обнаружения конца файла никакого специального механизма не требуется.
Файлы с произвольным доступом
В предыдущих примерах использовались
long Seek(long
где
Значение
Описание
SeekOrigin.Begin
Поиск от начала файла
SeekOrigin.Current
Поиск от текущего положения
SeekOrigin.End
Поиск от конца файла
Следующая операция чтения или записи после вызова методаSeek будет выполняться, начиная с нового положения в файле, возвращаемого этим методом. Если во время поиска в файле возникает ошибка, то генерируется исключениеIOException.Если же запрос положения в файле не поддерживается базовым потоком, то генерируется исключениеNotSupportedException.Кроме того, могут быть сгенерированы и другие исключения.
В приведенном ниже примере программы демонстрируется ввод-вывод в файл с произвольным доступом. Сначала в файл записываются прописные буквы английского алфавита, а затем его содержимое считывается обратно в произвольном порядке.
// Продемонстрировать произвольный доступ к файлу.
using System; using System.10;
class RandomAccessDemo { static void Main {
FileStream f = null; char ch;
try {
f = new FileStream("random.dat", FileMode.Create);
// Записать английский алфавит в файл, for (int i=0; i < 26; i++) f.WriteByte((byte)('A'+i));
//А теперь считать отдельные буквы английского алфавита. f.Seek(0, SeekOrigin.Begin); // найти первый байт ch = (char) f. ReadByte ;