我尝试搜索有关 long double 的信息,到目前为止,我了解编译器的实现方式不同。
在 Ubuntu (XUbuntu) Linux 12.10 上使用 GCC 时,我得到这个:
double PId = acos(-1);
long double PIl = acos(-1);
std::cout.precision(100);
std::cout << "PId " << sizeof(double) << " : " << PId << std::endl;
std::cout << "PIl " << sizeof(long double)  << " : " << PIl << std::endl;
输出:
PId 8  : 3.141592653589793115997963468544185161590576171875
PIl 16 : 3.141592653589793115997963468544185161590576171875
任何人都明白为什么他们输出(几乎)相同的东西?