ゼロによる浮動小数点除算を実行する小さなプログラムがあるので、SIGFPE を期待しています。
#include <sys/types.h>
#include <signal.h>
#include <stdio.h>
#include <stdlib.h>
#include <iostream>
void signal_handler (int signo) {
if(signo == SIGFPE) {
std::cout << "Caught FPE\n";
}
}
int main (void) {
signal(SIGFPE,(*signal_handler));
double b = 1.0;
double c = 0.0;
double d = b/c;
std::cout << "d = "<< d << std::endl;
return 0;
}
実際、次の出力が得られました。
d = inf
gcc バージョン 4.5.2 (Ubuntu/Linaro 4.5.2-8ubuntu4)
この場合、SIGFPE をスローするにはどうすればよいですか? FP 操作の動作はどの要因 (コンパイラ フラグ/CPU タイプなど) に依存しますか?
ありがとう