|
|
  |
Кто как работает с битами? |
|
|
|
Jun 20 2010, 22:44
|

неотягощённый злом
     
Группа: Свой
Сообщений: 2 746
Регистрация: 31-01-08
Из: Санкт-Петербург
Пользователь №: 34 643

|
Цитата(zltigo @ Jun 20 2010, 14:49)  А зачем приплетать всуе слова "критическая секция". Эта сущность в общем случае совершенно отдельная. Если Вы не задумываясь щедрой рукой разбрасываете volatile да critical, и знаете только одну систему команд, то это не значит, что все должны следовать Вашему "примеру" и разбрасываться ресурсами  . Пусть хоть один флаг волатилен, он и всех собратьев (из одного байта) сделает таковыми. Оно надо? Да я даю реально упрощающий жизнь пример. Когда не надо помнить ни про волатильность ни про то что особо умный и жадный программист разделил волатильные флаги от неволатильных, а потом забыл об этом ненароком он сам или наследники его таланта. Зачем закладывать грабли когда можно и нужно без них обходиться. Просто. Надёжно. Без геморроя. Быстро и не требует лишней писанины (я об описании через дефайны мути в виде масок, что вообще применимо лишь для описании периферии). Хочется воскликнуть: Ау! мы пишем на Си а не на я языке препроцессора в конце то концов... А Вы всё о какой-то мифической экономии ресурсов печётесь. Не здесь блох ловить стоит 20 байт озу и 5-20 тиков тактовой. Не мне Вам объяснять где. Вы сами прекрасно знаете про вынесение из цикла всякой чуши, про их разворачивание, про правильный (нативный) выбор типов данных и про уместное использование volatile да и вообще о культуре программирования. А то право смешно даже становится как Вы упираетесь и особо смешно, что даже немного грустно, от того что Ваша привычка домысливать и додумывать об умениях и интеллекте Ваших собеседников крепчает с годами... Радует что пока до обсуждения ближайших родственников оппонентов дело не доходит... Цитата(MALLOY2 @ Jun 20 2010, 20:34)  Совершенно зря, у Cortex есть фича упрощающая работу с битами называется она "Bit Banding"Все ваши флаги можно было упаковать в одно слово, а там работай хоть через маски хоть через Bit Banding. Это отлично! Через пару месяцев ему потребуется портировать проект под процессор XXX с адресным пространством чуть меньшим чем 4Gb без Bit Banding... "О сколько нам открытий чудных готовит просвещения дух!" - это я не к тому чтобы не использовать новую полезную фичу, а к тому что и старая даёт сопоставимый результат. Ну нет в Си полноценного типа данных меньшего чем uint_fast8_t!
--------------------
“Будьте внимательны к своим мыслям - они начало поступков” (Лао-Цзы)
|
|
|
|
|
Jun 21 2010, 05:49
|
Знающий
   
Группа: Validating
Сообщений: 838
Регистрация: 31-01-05
Пользователь №: 2 317

|
Цитата Это отлично! Через пару месяцев ему потребуется портировать проект под процессор XXX и какие проблемы ? Все зависит как вы опишете Bit Banding, так вы его и портируете. Использовать 8-битный тип для флагов это двойной геморой, первое это расход памяти, второе это компилятор всегда расширяет 8 бит до 32 бит, а это для кортекса 1 лишняя команда.
|
|
|
|
|
Jun 21 2010, 06:09
|

Гуру
     
Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244

|
QUOTE (demiurg_spb @ Jun 21 2010, 00:44)  Да я даю реально упрощающий жизнь пример. Когда не надо помнить ни.... Если не хочется помнить, знать, отвечать, то надо идти в дворники, ну или программисты 1C - там всякие бездумные действия порядке вещей. QUOTE и про уместное использование volatile да и вообще о культуре программирования. Вот именно по этой причине меня и задевает пропаганда "реально упрощающий жизнь пример. Когда не надо помнить" подход к программированию  .
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Jun 21 2010, 06:25
|

Беспросветный оптимист
     
Группа: Свой
Сообщений: 4 640
Регистрация: 26-12-07
Из: Н.Новгород
Пользователь №: 33 646

|
Цитата(MrYuran @ Jun 20 2010, 12:11)  Компилятор сам не дурак, решит, где удобнее маску наложить, где подвигать, а где битовые команды (если они есть) использовать. Таким образом, надо писать так, как удобнее. Поэтому предлагаю описать так: Код struct { FLAG( D0 ); FLAG( D1 ); ... }stFlags; , где FLAG можно описать макросом #define FLAG(FlagName) unsigned char FlagName : 1 либо #define FLAG(FlagName) unsigned char FlagName либо #define FLAG(FlagName) FlagType FlagName
--------------------
Программирование делится на системное и бессистемное. ©Моё :) — а для кого-то БГ — это Bill Gilbert =)
|
|
|
|
|
Jun 21 2010, 08:09
|

неотягощённый злом
     
Группа: Свой
Сообщений: 2 746
Регистрация: 31-01-08
Из: Санкт-Петербург
Пользователь №: 34 643

|
Цитата(zltigo @ Jun 21 2010, 10:09)  Если не хочется помнить, знать, отвечать, то надо идти в дворники, ну или программисты 1C - там всякие бездумные действия порядке вещей. Опять 25... Обобщаем обобщаемое... Еще забыли сказать, что всю Россию пропили... А моих доводов ЗА так и не увидели. Я ваш единственный довод об увеличении производительности парировал своими доводами. А Вы всё юлите и в общемировые проблемы уходите и проблемы частного индивида. Цитата Вот именно по этой причине меня и задевает пропаганда "реально упрощающий жизнь пример. Когда не надо помнить" подход к программированию  . Ну не хотите Вы понять что прозрачно написанная программа это благо как ни крути. А любое привнесённое - это муть в чистой воде. Все я с Вами в такой манере больше не желаю общаться. И на том спасибо! Цитата(MALLOY2 @ Jun 21 2010, 09:49)  и какие проблемы ? Все зависит как вы опишете Bit Banding, так вы его и портируете. Никаких проблем нет. Также как и явных преимуществ перед нативным типом. И тем что надо портировать и описывать. Цитата Использовать 8-битный тип для флагов это двойной геморой, первое это расход памяти, второе это компилятор всегда расширяет 8 бит до 32 бит, а это для кортекса 1 лишняя команда. Где вы увидели что я предлагал использовать "жёсткий" 8-ми битный тип? Да будет перерасход памяти. Это действительно плохо и ужасно. Сколько сейчас в среднем ставят на кортексах 8, 16К? Для ликбеза: как там в кортексе устроен механизм записи 32-битного регистра в ОЗУ атомарно? И бывает ли иначе?
--------------------
“Будьте внимательны к своим мыслям - они начало поступков” (Лао-Цзы)
|
|
|
|
|
Jun 21 2010, 08:50
|

неотягощённый злом
     
Группа: Свой
Сообщений: 2 746
Регистрация: 31-01-08
Из: Санкт-Петербург
Пользователь №: 34 643

|
Цитата(MrYuran @ Jun 21 2010, 10:25)  Поэтому предлагаю описать так: , где FLAG можно описать макросом Много букв:-) Но для мсп430 с его "огромным" ОЗУ иногда и так может сгодиться или "даже хуже": просто битовое поле или просто байты с масками. Цитата(Tanya @ Jun 21 2010, 12:37)  А я вот... делаю и так и эдак. Если быстро флаги (семафоры) не нужны, пакую, а если быстро - то не экономлю. И правильно делаете. Цитата Спор этот напоминает... тупоконечников и остроконечников... Не будем уточнять кто есть кто  Цитата(zltigo @ Jun 21 2010, 12:19)  Оценка степени прозрачности программ прежде всего зависит от количества мути в голове оценивающего  . Критерий один - отсутствие мути. Муть в данном случае буковки. Много буковок. ООООчень много буковок и макросов и разделений на своих и чужих.
--------------------
“Будьте внимательны к своим мыслям - они начало поступков” (Лао-Цзы)
|
|
|
|
|
Jun 21 2010, 14:48
|
Гуру
     
Группа: Свой
Сообщений: 10 920
Регистрация: 5-04-05
Пользователь №: 3 882

|
Цитата(ViKo @ Jun 21 2010, 19:20)  Если определить несколько переменных типа bool, компилятор не объединит их в один байт/слово... ? Сам по себе - нет. Тип bool в C99 макросом преобразуется в _Bool, который в свою очередь имеет размерность int.
|
|
|
|
|
Jun 21 2010, 15:14
|
Гуру
     
Группа: Свой
Сообщений: 10 920
Регистрация: 5-04-05
Пользователь №: 3 882

|
Цитата(Herz @ Jun 21 2010, 21:03)  ? Не читайте советских газет перед обедом не ориентируйтесь на Википедию как на истину в последней инстанции. Справляйтесь у оригинала стандарта ISO/IEC 9899:1999 (E). Цитата 7.18.1.3 Fastest minimum-width integer types 1Each of the following types designates an integer type that is usually fastest 216) to operate with among all integer types that have atleast the specified width. 2The typedef name int_fastN_t designates the fastest signed integer type with a width of at least N.The typedef name uint_fastN_t designates the fastest unsigned integer type with a width of at least N. 3The following types are required: int_fast8_t int_fast16_t int_fast32_t int_fast64_t uint_fast8_t uint_fast16_t uint_fast32_t uint_fast64_t All other types of this form are optional.
|
|
|
|
|
  |
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|