"Мюррэй Хилл, Бьярн Страустрап. Язык С++" - читать интересную книгу автора extern int error_number;
typedef complex point; float real(complex* p) { return p->re; }; const double pi = 3.1415926535897932385; struct user; Как можно видеть из этих примеров, описание может делать больше чем просто ассоциировать тип с именем. Большинство описаний являются также определениями; то есть они также определяют для имени сущность, к которой оно относится. Для ch, count и cvar этой сущностью является соответствующий объем памяти, который должен использоваться как переменная - эта память будет выделена. Для real это заданная функция. Для constant pi это значение 3.1415926535897932385. Для complex этой сущностью является новый тип. Для point это тип complex, поэтому point становится синонимом complex. Только описания extern complex sqrt(complex); extern int error_number; struct user; - стр 48 - не являются одновременно определениями. Это означает, что объект, к которому они относятся, должен быть определен где-то еще. Код (тело) функции sqrt должен задаваться неким другим описанием, другим описанием, и какое-то другое описание типа user должно определять, что он из себя представляет. В C++ программе всегда должно быть только одно определение каждого имени, но описаний может быть много, и все описания должны согласовываться с типом объекта, к которому они относятся, поэтому в этом фрагменте есть две ошибки: int count; int count; // ошибка: переопределение exnern int error_number; exnern int error_number; // ошибка: несоответствие типов а в этом - ниодной (об использовании extern см. #4.2): exnern int error_number; exnern int error_number; Некотрые описания задают "значение" для сущностей, которые они определяют: struct complex { float re, im; }; typedef complex point; float real(complex* p) { return p->re }; const double pi = 3.1415926535897932385; |
|
|