1.long double支持的问题
测试程序:
#include <stdio.h> int main() { long double r = 0.0; double b=0.0; scanf("%Lf",&r); r=r*r; printf("%Lf/n",r); printf("size=%d/n",sizeof(r)); printf("size=%d",sizeof(b)); return 0; }
(1)Tiny C
编译0警告,0错误
执行,scanf无法接受数据
(2)MinGW
编译警告,不认识“L”格式字符
执行,scanf无法接受数据
(3)微软VC2005-2010
编译警告scanf过时,推荐用scanf_s代替 0错误
忽略警告,执行成功,一切正常。
发现微软VC中double 和long double都是8个字节,也就是说微软实际上是伪支持long double,而TCC和MinGW中都是12个字节的long double。
难怪不出问题
1,2的失败的原因是因为调用的是微软的C运行时库,而微软本来就不是真正的支持long double.不过连L这个格式字符串都识别不了,说明MinGW还是做的不够好。这是标准C的应该支持的东西。MinGW对C++编译的时候调用的是GCC的库,因此采用C++文件,cin和cout是可以输入输出真正的long double的。
(4) borland c++ 5.5.1
这个方面表现最好的是bc++.
编译0警告,0错误
执行,全部正确
Bc真正支持long double,和Gcc不一样,bc的long double 是10个字节,非常符合IEEE标准。
(5)Digital Mars C/C++ Compilers
这个编译器非常不错,表现和borland C++编译器一样。
编译0警告,0错误
执行,全部正确,真正支持long double,长度也是10。
但是编译出来的执行文件比b还要小。
(6)openwatcom c++ 1.9
这个编译器表现和VC非常相似。
编译0警告,0错误
执行,全部正确。
只是他的long double是8个字节的,和微软一样,其实就是double,是假支持。
编译出来的文件比较小,和DM相当。
这个编译器的附件工具做的很好,特别是那个图形化的调试器,还不错。
2。局部变量定义的问题
在VC中如果建立C语言程序,局部变量的定义必须放在开始,不能插在两个执行语句之间,否则编译通不过!
但是在VC中,如果建立的是C++文件,则没有这个问题。
borlandC++的表现一样,对C语言不允许在语句之间定义局部变量。
但是在CB中,采用DM编译器,TinyC编译器,MINGW编译器,确都没有这个问题,要知道TCC是纯C编译器。
采用MinGW测试,也没有这个问题。这是否说明DM,TCC和MinGW在C支持方面比微软更加灵活?呵呵。