Чтение онлайн

на главную - закладки

Жанры

Linux программирование в примерах

Роббинс Арнольд

Шрифт:

14 /* emp_id_compare --- сравнение по ID */

15

16 int emp_id_compare(const void *e1p, const void *e2p)

17 {

18 const struct employee *e1, *e2;

19

20 e1 = (const struct employee*)e1p;

21 e2 = (const struct employee*)e2p;

22

23 if (e1->emp_id < e2->emp_id)

24 return -1;

25 else if (e1->emp_id == e2->emp_id)

26 return 0;

27 else

28 return 1;

29 }

30

31 /* print_employee --- напечатать структуру сотрудника */

32

33 void print_employee(const struct employee *emp)

34 {

35 printf("%s %s\t%d\t%s", emp->lastname, emp->firstname,

36 emp->emp_id, ctime(&emp->start_date));

37 }

Строки 7–12 определяют

struct employee
; она та же, что и раньше. Строки 16–29 служат в качестве функции сравнения как для
qsort
, так и для
bsearch
. Они сравнивают лишь ID сотрудников. Строки 33–37 определяют
print_employee
, которая является удобной функцией для печати структуры, поскольку это делается из разных мест.

39 /* main --- демонстрация сортировки */

40

41 int main(int argc, char **argv)

42 {

43 #define NPRES 10

44 struct employee presidents[NPRES];

45 int i, npres;

46 char buf[BUFSIZ];

47 struct employee *the_pres;

48 struct employee key;

49 int id;

50 FILE *fp;

51

52 if (argc != 2) {

53 fprintf(stderr, "usage: %s datafile\n", argv[0]);

54 exit(1);

55 }

56

57 if ((fp = fopen(argv[1], "r")) == NULL) {

58 fprintf(stderr, "%s: %s: could not open: %s\n", argv[0],

59 argv[1], strerror(errno));

60 exit(1);

61 }

62

63 /* Очень простой код для чтения данных: */

64 for (npres = 0; npres < NPRES && fgets(buf, BUFSIZ, fp) != NULL;

65 npres++) {

66 sscanf(buf, "%s %s %ld %ld",

67 presidents[npres].lastname,

68 presidents[npres].firstname,

69 &presidents[npres].emp_id,

70 &presidents[npres].start_date);

71 }

72 fclose(fp);

73

74 /* В npres теперь число действительно прочитанных строк. */

75

76 /* Сначала отсортировать по id */

77 qsort(presidents, npres, sizeof(struct employee), emp_id_compare);

78

79 /* Напечатать результат */

80 printf("Sorted by ID:\n");

81 for (i = 0; i < npres; i++) {

82 putchar('\t');

83 print_employee(&presidents[i]);

84 }

85

86 for (;;) {

87 printf("Enter ID number: ");

88 if (fgets(buf, BUFSIZ, stdin) == NULL)

89 break;

90

91 sscanf(buf, "%d\n", &id);

92 key.emp_id = id;

93 the_pres = (struct employee*)bsearch(&key, presidents,

94 npres, sizeof(struct employee), emp_id_compare);

95

96 if (the_pres != NULL) {

97 printf("Found: ");

98 print_employee(the_pres);

99 } else

100 printf("Employee with ID %d not found'\n", id);

101 }

102

103 putchar('\n'); /* Напечатать в конце символ новой строки. */

104

105 exit(0);

106 }

Функция

main
начинается с проверки аргументов (строки 52–55). Затем она читает данные из указанного файла (строки 57–72). Стандартный ввод для данных сотрудников использоваться не может, поскольку он зарезервирован для запроса у пользователя ID искомого сотрудника.

Строки 77–84 сортируют, а затем печатают данные. Затем программа входит в цикл, начинающийся со строки 86. Она запрашивает идентификационный номер сотрудника, выходя из цикла по достижению конца файла. Для поиска в массиве мы используем

struct employee
с именем
key
. Достаточно лишь установить в его поле emp_id введенный номер ID; другие поля при сравнении не используются (строка 92).

Если найден элемент с подходящим ключом,

bsearch
возвращает указатель на него. В противном случае она возвращает
NULL
. Возвращенное значение проверяется в строке 96, и осуществляется нужное действие. Наконец, строка 102 выводит символ конца строки, чтобы системное приглашение появилось с новой строки. Вот что появляется после компилирования и запуска программы:

Поделиться:
Популярные книги

Я все еще князь. Книга XXI

Дрейк Сириус
21. Дорогой барон!
Фантастика:
юмористическое фэнтези
попаданцы
аниме
5.00
рейтинг книги
Я все еще князь. Книга XXI

Наследие Маозари 3

Панежин Евгений
3. Наследие Маозари
Фантастика:
рпг
аниме
5.00
рейтинг книги
Наследие Маозари 3

Древесный маг Орловского княжества 2

Павлов Игорь Васильевич
2. Орловское княжество
Фантастика:
аниме
сказочная фантастика
фэнтези
попаданцы
5.00
рейтинг книги
Древесный маг Орловского княжества 2

Газлайтер. Том 21

Володин Григорий Григорьевич
21. История Телепата
Фантастика:
боевая фантастика
аниме
попаданцы
5.00
рейтинг книги
Газлайтер. Том 21

Пересмешник

Пехов Алексей Юрьевич
Фантастика:
фэнтези
9.38
рейтинг книги
Пересмешник

Варвара Асенкова

Алянский Юрий Лазаревич
Корифеи русской и зарубежной сцены
Документальная литература:
биографии и мемуары
5.00
рейтинг книги
Варвара Асенкова

На границе империй. Том 10. Часть 6

INDIGO
Вселенная EVE Online
Фантастика:
боевая фантастика
космическая фантастика
попаданцы
5.00
рейтинг книги
На границе империй. Том 10. Часть 6

Клан

Русич Антон
2. Долгий путь домой
Фантастика:
боевая фантастика
космическая фантастика
5.60
рейтинг книги
Клан

Я уже царь. Книга XXIX

Дрейк Сириус
29. Дорогой барон!
Фантастика:
юмористическое фэнтези
аниме
попаданцы
5.00
рейтинг книги
Я уже царь. Книга XXIX

Вечный. Книга IV

Рокотов Алексей
4. Вечный
Фантастика:
боевая фантастика
попаданцы
рпг
5.00
рейтинг книги
Вечный. Книга IV

Ученик. Книга вторая

Первухин Андрей Евгеньевич
2. Ученик
Фантастика:
фэнтези
5.40
рейтинг книги
Ученик. Книга вторая

Некромант

Щепетнов Евгений Владимирович
4. Петр Синельников
Фантастика:
боевая фантастика
6.20
рейтинг книги
Некромант

Бояръ-Аниме. Газлайтер. Том 35

Володин Григорий Григорьевич
35. История Телепата
Фантастика:
аниме
боевая фантастика
фэнтези
5.00
рейтинг книги
Бояръ-Аниме. Газлайтер. Том 35

Кодекс Крови. Книга ХVIII

Борзых М.
18. РОС: Кодекс Крови
Фантастика:
попаданцы
аниме
фэнтези
5.00
рейтинг книги
Кодекс Крови. Книга ХVIII