ВходНаше всё Теги codebook 无线电组件 Поиск Опросы Закон Пятница
29 марта
1151398 Топик полностью
Vit (05.12.2021 01:27, просмотров: 251) ответил RxTx на "Правильно только это", потому что компилятор не философ, он работает учитывая синтаксические и семантические правила. И не заменяет правила трепом и переходом на личности людей. Если что-то неверно, не надо как капитан очевидность пересказывать известное и очевидное. Просто безотносительно личностей пишешь: это неверено, и приводишь аргументированные доказательства. Я никого не оскорблял, грубо не выражался, с чего вообще ты до меня докопался на ровном месте? Угомонись
"Правильно только это" - для меня это снисходительный тон кафедрального лаборанта. Не пытайся быть таким и я тебе не скажу куда идти. Если не понимаешь что-то - спроси, может договоримся о терминах. 

Твоё "правило" - опять хоровод. Слово struct может быть после pack как при "голом" объявлении типа, то же с typedef, может быть при явном объявлении структуры некоего набранного тут же типа с именем. Ещё имеется неполное объявление типа, в т.ч. указателей. Мелкософт стесняется рассказывать явно перед которым из слов struct прагма будет работать, а перед которым нет.

В разных компиляторах даже синтаксис этих прагм разный. Ещё есть атрибуты, сними чуть проще, но тоже некоторая грусть. Самое же в прагмах упаковки поганое - они практически всегда действуют при выделении памяти. Потому и мурашки при вложенности, extern, передаче формальных параметров в функцию.

Ещё существуют и с самими struct неопределенности насчет выделения памяти, оптимизации, области видимости, и нюансы использования алиасов как отдельных типов (особенно интересно неполное объявление указателей типа структуры через typedef при разовом использовании - некоторые применяют для замены явного включения хедеров).

При этом в gcc ещё и ожидаемо разное поведение, например, в зависимости от флагов no-common и no-strict-aliasing. При "голом" объявлении типа память не должна выделяться, но тоже не всё однозначно.