Телесистемы
 Разработка, производство и продажа радиоэлектронной аппаратуры
На главную   | Карта сайта | Пишите нам | В избранное
Требуется программист в Зеленограде
- обработка данных с датчиков; ColdFire; 40 тыс.
e-mail:jobsmp@pochta.ru

Телесистемы | Электроника | Конференция «Микроконтроллеры и их применение»

трактовка чисел как булевских значений - это изъян, изначально заложенный в язык Си. Паскать от этого изъяна ушёл, строго разделив типы, но лучше всего булево-числовое сосуществование реализовано в Lua (+)

Отправлено Токовый клещ (95.31.92.218) 10 апреля 2011, г. 14:23
В ответ на: Не надо тянуть сюда паскаль. Паскалю до Си - как до киева раком (писАл и на паскале). Тем более. что с "#define true 1" можете попасть. В Си есть 0 и не 0. И это очень логично, т.к. процессор выполняет проверку на ноль. Т.е 45и32=истина, но это не равнго вашему true отправлено Юрий_СВ 09 апреля 2011, г. 22:19

там все числа, включая 0 - это логическая истина
логические выражения вычисляются "ленивым" образом и числа никогда автоматически не переводятся в булевское значение, выполнение операций and и or над числами не интерпретируется как побитовая операция (как это имеет место в Паскале), поэтому в Lua выражение 0 and 1 даст результат 1, а выражение 1 and 0 будет равно 0

Благодаря такой странности возможна компактная конструкция
A = B and C or D
аналогичная Сишной
A = B?C:D

например, запись
A = B < 0 and -B or B
вычисляет модуль


Составить ответ | Вернуться на конференцию

Ответы


Отправка ответа
Имя*: 
Пароль: 
E-mail: 
Тема*:

Сообщение:

Ссылка на URL: 
URL изображения: 

если вы незарегистрированный на форуме пользователь, то
для успешного добавления сообщения заполните поле, как указано ниже:
к трём прибавьте 5:

Перейти к списку ответов | Конференция | Раздел "Электроника" | Главная страница | Карта сайта

Rambler's Top100 Рейтинг@Mail.ru
 
Web telesys.ru