Linux программирование в примерах | страница 82



>68  if (rcount < 0) {

>69   fprintf(stderr, "%s: %s: read error: %s\n",

>70    myname, file, strerror(errno));

>71   errors++;

>72  }

>73

>74  if (fd != 0) {

>75   if (close(fd) < 0) {

>76    fprintf(stderr, "%s: %s: close error: %s\n",

>77     myname, file, strerror(errno));

>78    errors++;

>79   }

>80  }

>81

>82  return (errors != 0);

>83 }

>ch04-cat проверяет на ошибки каждый системный вызов. Хотя это утомительно, зато предоставляет устойчивость (или по крайней мере, ясность): когда что-то идет не так, >ch04-cat выводит сообщение об ошибке, которое специфично настолько, насколько это возможно. В сочетании с >errno и >strerror() это просто. Вот все с >ch04-cat, всего 88 строк кода!

Для подведения итогов вот несколько важных моментов, которые нужно понять относительно ввода/вывода в Unix:

Ввод/вывод не интерпретируется

Системные вызовы ввода/вывода просто перемешают байты. Они не интерпретируют данные; вся интерпретация оставлена программе уровня пользователя. Это делает чтение и запись двоичных структур таким же простым, как чтение и запись строк текста (на самом деле, проще, хотя использование двоичных данных привносит проблемы переносимости).

Ввод/вывод гибок

За один раз вы можете прочесть или записать столько байтов, сколько захотите. Вы можете даже читать или записывать данные по одному байту за раз, хотя для больших объемов данных это обходится дороже, чем использование больших порций.

Ввод/вывод прост

Три уровня возвращаемых значений (отрицательные для ошибок, ноль для конца файла и положительные для счета) делают программирование простым и очевидным.

Ввод/вывод может быть частичным

Как >read(), так и >write() могут переместить меньше байтов, чем запрошено. Код приложения (т.е. ваш код) всегда должен учитывать это.

4.4.4. Пример: Unix >cat

Как и было обещано, вот версия cat V7[47]. Она начинается с проверки опций, >cat V7 принимает единственную опцию, >-u, для осуществления небуферированного вывода.

Общая структура сходна с той, которую мы видели ранее; программа перечисляет файлы, указанные в аргументах командной строки и читает каждый файл, по одному символу за раз, посылая этот символ в стандартный вывод. В отличие от нашей версии, она использует возможности >. Во многих случаях код, использующий стандартную библиотеку ввода/вывода, проще читать и писать, поскольку все проблемы с буферами скрыты библиотекой.

>1  /*

>2   * Объединение файлов.

>3   */

>4

>5  #include

>6  #include

>7  #include