реклама на сайте
подробности

 
 
2 страниц V  < 1 2  
Reply to this topicStart new topic
> bool "третье состояние"
ReAl
сообщение Jul 22 2009, 19:52
Сообщение #16


Нечётный пользователь.
******

Группа: Свой
Сообщений: 2 033
Регистрация: 26-05-05
Из: Бровари, Україна
Пользователь №: 5 417



Цитата(sergeeff @ Jul 22 2009, 20:15) *
Судя по тому, что вы подключаете в проект файл stdbool.h - тип bool не встроен в компилятор, а реализован через некоторое переопределение
Если компилятор соответствует стандарту С99, то он должен иметь

  • встроенный тип _Bool с рангом ниже любого целочисленного типа, способный вместить 0 и 1, при приведении любого скалярного значения к _Bool оно приводится как (val == 0 ? 0 : 1)
  • стандартный включаемый файл stdbool.h, который определяет
    #define bool _Bool
    #define true 1
    #define false 0


Так что если обсуждаемая ситуация касается С99-режима компиляции и bool не переопределён пользователем, то после
Код
bool b;

b = 13;
в b будет корректное значение, ну а
Код
*(unsigned char *)&b = 13;
как уже говорилось - неконтролируемая компилятором порнография, приводящая к UB.
И при
Код
bool b, b1;
*(unsigned char *)&b = 13;
b1 = b;
// и даже
b1 = (bool)b;
компилятор не обязан ничего проверять и "переприводить" - он не виноват, что в b левыми путями натолкали мусор.
Частными случаями UB может быть и ожидаемое программистом поведение, и совершенно противоположное.
Код
b1 = (bool)(int)b;
должно бы работать правильно, но не лучше ли обойтись без извращений?


--------------------
Ну, я пошёл… Если что – звоните…
Go to the top of the page
 
+Quote Post
KRS
сообщение Jul 22 2009, 21:02
Сообщение #17


Профессионал
*****

Группа: Модераторы
Сообщений: 1 951
Регистрация: 27-08-04
Из: Санкт-Петербург
Пользователь №: 555



Цитата(Xenia @ Jul 22 2009, 15:00) *
Это потому, что поверка одного бита "стоит" ровно столько же, сколько проверка всех битов - тестирование регистра на нулевое значение занимает столько же инструкций, как и тестирование одного его бита.

Это для очень многих процессоров не правда! Во многих случаях проверка на нулевое значение быстрее(инструкция меньше места занимает) или вообще не требует инструкции!

К тому же очень полезно смотреть листинги, на максимальной оптимизации! И будет видно как компилер работает с булевыми переменными.
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Jul 22 2009, 23:27
Сообщение #18


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



Цитата(ReAl @ Jul 22 2009, 22:52) *
Код
b1 = (bool)(int)b;
должно бы работать правильно
Что-то меня сомнения гложат. Тогда уж и вылезать через ту же дырку,через которую влезли:
Код
b = (bool)(*(unsigned char *)&b);


Цитата(HEX @ Jul 22 2009, 17:57) *
да жульничество, но интервейс вызова Read(void* Buff, int N) достаточно широко используется,
Угу. Для чтения тех же типов данных, которые были записаны при помощи Write(void* Buff,int N).


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
sensor_ua
сообщение Jul 23 2009, 08:28
Сообщение #19


Профессионал
*****

Группа: Свой
Сообщений: 1 266
Регистрация: 22-04-05
Из: Киев
Пользователь №: 4 387



Использование выражений типа
Код
if(a == true)

само по себе вроде и не страшно, но неправильно, потому как проверять по равенству/неравенству действительно можно только на false
Цитата
как
Код
(val == 0 ? 0 : 1)

Цитата
стандартный включаемый файл stdbool.h, который определяет
#define bool _Bool
#define true 1
#define false 0

Использую чуть другие буквы и не использую файл stdbool.h
Код
#define false 0
#define true (!(false))

Последняя строчка априори верна. true в таком случае опять же равно +1.
Но, IMHO, использование в Си беззнаковых типов для bool и положительного значения для true это какая-то диверсия, что ли. Из знакового в беззнаковое преобразовать практически всегда возможно, а вот наоборот нет. Использую знаковое представление.
Код
typedef int bool; // для 8-и-битников typedef signed char bool

Хотя это, если таки пытаться делать проверку на true, вылазит боком при использовании структур с битовыми полями объявленного знакового типа bool. Тогда компилятор при знаковом целом типе для bool считает значение поля не как 1, а как -1, а сравнение с true просто никогда не работает (ну и не очень-то и хотелосьwink.gif).


--------------------
aka Vit
Go to the top of the page
 
+Quote Post

2 страниц V  < 1 2
Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 6th July 2025 - 21:08
Рейтинг@Mail.ru


Страница сгенерированна за 0.01384 секунд с 7
ELECTRONIX ©2004-2016