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

 
 
 
Reply to this topicStart new topic
> Да неужто нет никакого способа С-препроцессором проверить float на больше-меньше?
Dr.Alex
сообщение Dec 6 2014, 11:33
Сообщение #1


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

Группа: Свой
Сообщений: 1 386
Регистрация: 5-04-05
Из: моська, RF
Пользователь №: 3 863



?
Go to the top of the page
 
+Quote Post
scifi
сообщение Dec 6 2014, 11:59
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 3 020
Регистрация: 7-02-07
Пользователь №: 25 136



ИМХО, нет.
Go to the top of the page
 
+Quote Post
Dr.Alex
сообщение Dec 6 2014, 12:19
Сообщение #3


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

Группа: Свой
Сообщений: 1 386
Регистрация: 5-04-05
Из: моська, RF
Пользователь №: 3 863



Цитата(scifi @ Dec 6 2014, 15:59) *
ИМХО, нет.


И статически преобразовать float в int соотвецно тоже? :-о
Go to the top of the page
 
+Quote Post
SM
сообщение Dec 6 2014, 14:08
Сообщение #4


Гуру
******

Группа: Свой
Сообщений: 7 946
Регистрация: 25-02-05
Из: Moscow, Russia
Пользователь №: 2 881



IMHO, все четко и ясно....


The `#if' directive allows you to test the value of an arithmetic expression, rather than the mere existence of one macro. Its syntax is

#if expression

controlled text

#endif /* expression */

expression is a C expression of integer type, subject to stringent restrictions. It may contain

- Integer constants.
- Character constants, which are interpreted as they would be in normal code.
- Arithmetic operators for addition, subtraction, multiplication, division, bitwise operations, shifts, comparisons, and logical operations (&& and ||). The latter two obey the usual short-circuiting rules of standard C.
- Macros. All macros in the expression are expanded before actual computation of the expression's value begins.
- Uses of the defined operator, which lets you check whether macros are defined in the middle of an `#if'.
- Identifiers that are not macros, which are all considered to be the number zero. This allows you to write #if MACRO instead of #ifdef MACRO, if you know that MACRO, when defined, will always have a nonzero value. Function-like macros used without their function call parentheses are also treated as zero.


Так что, увы, никакого float там.
Однако, никто не мешает на оптимизатор возложить часть расчетов. Всякие там if (0) {} им убиваются на раз, и типы он преобразует как надо.
Go to the top of the page
 
+Quote Post
scifi
сообщение Dec 6 2014, 16:20
Сообщение #5


Гуру
******

Группа: Свой
Сообщений: 3 020
Регистрация: 7-02-07
Пользователь №: 25 136



Цитата(Dr.Alex @ Dec 6 2014, 15:19) *
И статически преобразовать float в int соотвецно тоже? :-о

Всё-таки препроцессор и компилятор - это "две большие разницы". Собственно, SM процитировал исчерпывающую информацию. Это был текст из руководства на gcc, но в стандарте C99 по сути написано то же самое.
Go to the top of the page
 
+Quote Post
psL
сообщение Dec 7 2014, 11:44
Сообщение #6


Знающий
****

Группа: Свой
Сообщений: 526
Регистрация: 5-08-05
Пользователь №: 7 390



Видимо можно как-то так:
Код
#define PRECISION   (1000)
#define FLOAT2INT(x,y)  (x*PRECISION+y)
#define INT2FLOAT(x)    ((float)x/PRECISION)

#define LEVEL  FLOAT2INT(1,250)

#if (LEVEL > FLOAT2INT(1,300))
    #error LEVEL > 1,300
#endif

float level = INT2FLOAT(LEVEL);

int main()
{
    printf("Level: %f\n", level);
    return 0;
}

только не очень удобно следить за размером поля дробной части
Go to the top of the page
 
+Quote Post
Dr.Alex
сообщение Dec 7 2014, 12:00
Сообщение #7


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

Группа: Свой
Сообщений: 1 386
Регистрация: 5-04-05
Из: моська, RF
Пользователь №: 3 863



Нельзя, флоат сколько не умножай, интом он не станет..
Go to the top of the page
 
+Quote Post

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

 


RSS Текстовая версия Сейчас: 22nd July 2025 - 00:39
Рейтинг@Mail.ru


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