Вопросы по С/С++ (СИ)
- Сообщения: 12867
- Зарегистрирован: Сб дек 18, 2021 19:25:32
упс
Последний раз редактировалось Martian Пт май 03, 2024 05:48:39, всего редактировалось 1 раз.
- Реклама
Я сейчас вот такой код попробовал.
Результат 0xFF01.
Ворнинга нет. Компилятор IAR. Пробовал выбирать Stantard C, C89 и С++.
Код: Выделить всё
volatile uint8_t a=0xFF;
volatile uint16_t v=a<<8 | (uint8_t)1;Ворнинга нет. Компилятор IAR. Пробовал выбирать Stantard C, C89 и С++.
- Сообщения: 2562
- Зарегистрирован: Вт май 01, 2018 19:44:47
Если прогуливать уроки физики в школе, то мир наполнится магией и волшебством 
Точно так же, если не читать стандарты на язык программирования. Ключевые слова "Integer Promotions".
Точно так же, если не читать стандарты на язык программирования. Ключевые слова "Integer Promotions".
- Сообщения: 12867
- Зарегистрирован: Сб дек 18, 2021 19:25:32
Значит, OKF прав, а я - нет. Поставим ему плюсик...
И всё же, я предпочту явное приведение неявному. И кучу скобок. Возможно, ресурс клавиатуры при этом сокращается, но зато в разы меньше проявляется ошибок, чем когда писал в стиле "тут и ежу понятно". И я точно помню, что когда-то давно сталкивался с отсутствием расширяющегося приведения операндов при сдвиге. Увы, не смог вспомнить, где.
И всё же, я предпочту явное приведение неявному. И кучу скобок. Возможно, ресурс клавиатуры при этом сокращается, но зато в разы меньше проявляется ошибок, чем когда писал в стиле "тут и ежу понятно". И я точно помню, что когда-то давно сталкивался с отсутствием расширяющегося приведения операндов при сдвиге. Увы, не смог вспомнить, где.
[uquote="Martian",url="/forum/viewtopic.php?p=4575532#p4575532"]a << сb | c(d)[/uquote]
Давненько не писал на Си, а для МК - вообще никогда. Но заинтересовала эта конструкция. Следуя K & R, насколько я их помню, едино что приходит на ум - процедура c с парамеиром d . Но это, конечно, не так?
Давненько не писал на Си, а для МК - вообще никогда. Но заинтересовала эта конструкция. Следуя K & R, насколько я их помню, едино что приходит на ум - процедура c с парамеиром d . Но это, конечно, не так?
- Реклама
- Сообщения: 2562
- Зарегистрирован: Вт май 01, 2018 19:44:47
Это точно не процедура, в С тупо нет процедур, а есть функции. А c(d) может быть как вызовом функции, так и макросом или даже приведением типа. Всё зависит от того что есть c.
- Сообщения: 1410
- Зарегистрирован: Вт июн 07, 2011 08:03:18
[uquote="VladislavS",url="/forum/viewtopic.php?p=4575611#p4575611"]Если прогуливать уроки физики в школе, то мир наполнится магией и волшебством 
Точно так же, если не читать стандарты на язык программирования. Ключевые слова "Integer Promotions".[/uquote]
Да. Люблю волшебство.) Ну а беда в том что стандарт не определяет последовательность вычисления операндов:
Except where noted, evaluations of operands of individual operators and of subexpressions of individual expressions are unsequenced ... The value computations of the operands of an operator are sequenced before the value computation of the result of the operator. If a side effect on a memory location (4.4) is unsequenced relative to either another side effect on the same memory location or a value computation using the value of any object in the same memory location, and they are not potentially concurrent (4.7) , the behavior is undefined (ISO/IEC 14882:2017 разд. 4.6(17) стр. 14)
Точно так же, если не читать стандарты на язык программирования. Ключевые слова "Integer Promotions".[/uquote]
Да. Люблю волшебство.) Ну а беда в том что стандарт не определяет последовательность вычисления операндов:
Except where noted, evaluations of operands of individual operators and of subexpressions of individual expressions are unsequenced ... The value computations of the operands of an operator are sequenced before the value computation of the result of the operator. If a side effect on a memory location (4.4) is unsequenced relative to either another side effect on the same memory location or a value computation using the value of any object in the same memory location, and they are not potentially concurrent (4.7) , the behavior is undefined (ISO/IEC 14882:2017 разд. 4.6(17) стр. 14)
- Сообщения: 2562
- Зарегистрирован: Вт май 01, 2018 19:44:47
Последовательность вычисления не может перепрыгнуть через приоритеты операций и не меняет разрядность вычислений. В выражениях без побочных эффектов непринципиальна.
- Сообщения: 12867
- Зарегистрирован: Сб дек 18, 2021 19:25:32
В примере к WCH RISC-V встретилась любопытная конструкция:
Мне казалось, что аргументом функции должен стать результат одного из результатов тернарной операции, но это не так (да и он всегда истинен)
Тут тоже как-то хитро работает приоритетность?
Код: Выделить всё
GPIO_WriteBit(GPIOD, GPIO_Pin_0, (i == 0) ? (i = Bit_SET) : (i = Bit_RESET));Тут тоже как-то хитро работает приоритетность?
Я крайне редко пользуюсь тернарным оператором. Боюсь ошибиться.
Но ведь он не просто выполняет одно из выражений , но и возвращает его результат.
Добавлено after 2 minutes 22 seconds:
Но ведь он не просто выполняет одно из выражений , но и возвращает его результат.
Добавлено after 2 minutes 22 seconds:
кто?Martian писал(а):да и он всегда истинен)
- Сообщения: 2562
- Зарегистрирован: Вт май 01, 2018 19:44:47
Третьим аргументом функции GPIO_WriteBit() будет значение выражения которое при каждом вызове будет менять своё значение с Bit_SET на Bit_RESET и наоборот. Так дрыганье ногой сделали. Пример в Compiler Explorer.
ЗЫ:
У меня в коде вот такая приколюха с тернарником есть
Код: Выделить всё
(i == 0) ? (i = Bit_SET) : (i = Bit_RESET)ЗЫ:
У меня в коде вот такая приколюха с тернарником есть
Код: Выделить всё
bool isKeyPressed() { return key_pressed ? key_pressed=false,true : false; }
- Сообщения: 12867
- Зарегистрирован: Сб дек 18, 2021 19:25:32
тоже красиво )
я решил глянуть, как в ассемблере вышло и застрял за разбирательством "что такое риск-ви"
А ведь это очень удобно...
Добавлено after 3 minutes 34 seconds:
[uquote="Z_h_e",url="/forum/viewtopic.php?p=4588480#p4588480"]кто?[/uquote] результат присваивания i = x; По крайней мере,
если слегка ошибиться и написать if (i = x), то у меня было когда-то, что это принималось за истину, и даже где-то читал описание, что в данном случае условие всегда истинно. Ща проверю.
Добавлено after 3 minutes 41 second:
ага, здесь точно также, условие определяется итоговым значением переменной.
класс. ещё одно моё заблуждение...
Z_h_e, спасибо за вопрос.
я решил глянуть, как в ассемблере вышло и застрял за разбирательством "что такое риск-ви"
о как! я думал на такое, но отбросил, как не кажущееся логичным. VladislavS, спасибо!VladislavS писал(а):будет менять своё значение с Bit_SET на Bit_RESET и наоборот. Пример в Compiler Explorer.
А ведь это очень удобно...
Добавлено after 3 minutes 34 seconds:
[uquote="Z_h_e",url="/forum/viewtopic.php?p=4588480#p4588480"]кто?[/uquote] результат присваивания i = x; По крайней мере,
если слегка ошибиться и написать if (i = x), то у меня было когда-то, что это принималось за истину, и даже где-то читал описание, что в данном случае условие всегда истинно. Ща проверю.
Добавлено after 3 minutes 41 second:
ага, здесь точно также, условие определяется итоговым значением переменной.
класс. ещё одно моё заблуждение...
Z_h_e, спасибо за вопрос.
Последний раз редактировалось Martian Пт июн 07, 2024 13:37:47, всего редактировалось 1 раз.
Так тернарный оператор возвращает фактический результат, а не булевый тип. То есть результатом i=x , будет x.
- Сообщения: 2562
- Зарегистрирован: Вт май 01, 2018 19:44:47
[uquote="Martian",url="/forum/viewtopic.php?p=4588538#p4588538"]результат присваивания i = x; По крайней мере,[/uquote]Оператор присваивания возвращает правое выражение. Это позволяет делать последовательные присваивания a=b=c;
- Сообщения: 12867
- Зарегистрирован: Сб дек 18, 2021 19:25:32
да, теперь понял.
[uquote="Martian",url="/forum/viewtopic.php?p=4588538#p4588538"]если слегка ошибиться и написать if (i = x), то у меня было когда-то, что это принималось за истину, и даже где-то читал описание, что в данном случае условие всегда истинно.[/uquote]
На Хабре недавно была статья, что почти все компиляторы стали выдавать предупреждение на присваивание в условии.
На Хабре недавно была статья, что почти все компиляторы стали выдавать предупреждение на присваивание в условии.
[ Всё дело не столько в вашей глупости, сколько в моей гениальности ] [ Правильно заданный вопрос содержит в себе половину ответа ]
- Сообщения: 12867
- Зарегистрирован: Сб дек 18, 2021 19:25:32
Да, те, которыми сейчас пользуюсь, все выдают. А давно когда-то пару раз уходило достаточно много времени на поиск такой опечатки...
==,!= вообще декоративные при том что - определен для всего что обычно сравнивают с их помощью
Всем доброго 
Подскажите по масками, точнее как записать в порт, в младшие байты, не изменив старших.??
Временная переменная tempo
Переменная с данными Х
В итоге собственно ничегошеньки не получается. (применяется для инициализации и записи в жки).
Не работает ни в протеус'е, ни на макете.
При прямой записи вида
Всё работает
Подскажите по масками, точнее как записать в порт, в младшие байты, не изменив старших.??
Временная переменная tempo
Переменная с данными Х
Код: Выделить всё
tempo=( (X>>4) & 0x0F);
PORT |=tempo;
..
...
tempo= (X & 0x0F);
PORT |=tempo;
...
...
Не работает ни в протеус'е, ни на макете.
При прямой записи вида
Код: Выделить всё
PORT =((X>>4) & 0x0F)
Интересная,однако,штука
Очень удобно: написать код, которому отдельный толмач нужен. Видимо, про веревку для выстрела в ногу нынче читать не модно... Перед функцией написать x = ! x и потом передать х в функцию (т.е. написать так, что даже умственно неполноценный разберется) - это не куто...
В принципе, чтобы прослыть крутым программистом, достаточно обфускатор скачать.
В принципе, чтобы прослыть крутым программистом, достаточно обфускатор скачать.
если рассматривать человека снизу, покажется, что мозг у него глубоко в жопе
при взгляде на многих сверху ничего не меняется...
Мой уютный бложик... заходите!
при взгляде на многих сверху ничего не меняется...
Мой уютный бложик... заходите!




