LINUX.ORG.RU

Функции в макросах

 ,


0

2

Тут сказано, что следующий код должен вернуть -8, но у меня 9, как и положено.

#include <stdio.h>

#define ABSOLUTE_VALUE( x ) ( ((x) < 0) ? -(x) : (x) )

int main(int agrc, char *argv[])
{
    int x = -10;
    int y = ABSOLUTE_VALUE( x++ );
    printf("y: %d\n", y);
    return 0;
}

Это опечатка или такое бывает в реальности? Если бывает, то где (какие компиляторы) и почему?

$ gcc -v
Using built-in specs.
COLLECT_GCC=gcc
COLLECT_LTO_WRAPPER=/usr/libexec/gcc/x86_64-redhat-linux/4.8.1/lto-wrapper
Target: x86_64-redhat-linux
Configured with: ../configure --prefix=/usr --mandir=/usr/share/man --infodir=/usr/share/info --with-bugurl=http://bugzilla.redhat.com/bugzilla --enable-bootstrap --enable-shared --enable-threads=posix --enable-checking=release --with-system-zlib --enable-__cxa_atexit --disable-libunwind-exceptions --enable-gnu-unique-object --enable-linker-build-id --with-linker-hash-style=gnu --enable-languages=c,c++,objc,obj-c++,java,fortran,ada,go,lto --enable-plugin --enable-initfini-array --enable-java-awt=gtk --disable-dssi --with-java-home=/usr/lib/jvm/java-1.5.0-gcj-1.5.0.0/jre --enable-libgcj-multifile --enable-java-maintainer-mode --with-ecj-jar=/usr/share/java/eclipse-ecj.jar --disable-libjava-multilib --with-isl=/builddir/build/BUILD/gcc-4.8.1-20130603/obj-x86_64-redhat-linux/isl-install --with-cloog=/builddir/build/BUILD/gcc-4.8.1-20130603/obj-x86_64-redhat-linux/cloog-install --with-tune=generic --with-arch_32=i686 --build=x86_64-redhat-linux
Thread model: posix
gcc version 4.8.1 20130603 (Red Hat 4.8.1-1) (GCC)

Ты инкремент-то замени: постфиксный на префиксный. Ну или посмотри, чему будет равно x после.

Anon ()
Ответ на: комментарий от Anon

Да, в примере говорилось про x, он у меня действительно равен -8. Теперь осталось понять почему так происходит.

gh0stwizard ★★★★★ ()
cat absval.c 
#include <stdio.h>

#define ABSOLUTE_VALUE( x ) ( ((x) < 0) ? -(x) : (x) )

int main(int agrc, char *argv[])
{
    int x = -10;
    int y = ABSOLUTE_VALUE( x++ );
    printf("y: %d; x = %d\n", y, x);
    return 0;
}

gcc absval.c -Wall -Werror -o absv && ./absv 
y: 9; x = -8

Все правильно работает.

Anon ()
Ответ на: комментарий от gh0stwizard

А что непонятного-то? Ты раскрой макрос. Если лень ручками делать, набери gcc -E, получишь:

int y = ( ((x++) < 0) ? -(x++) : (x++) );
Anon ()
Ответ на: комментарий от Anon

Если лень ручками делать, набери gcc -E, получишь

Все, понял. Спасибо.

gh0stwizard ★★★★★ ()

gcc -E tmp1.c

....


int main(int agrc, char *argv[])
{
    int x = -10;
    int y = ( ((x++) < 0) ? -(x++) : (x++) );
    printf("y: %d\n", y);
    return 0;
}
anonymous ()

остаётся вопрос: при чём тут сабж?

emulek ()
Вы не можете добавлять комментарии в эту тему. Тема перемещена в архив.