关于不同的编译器使用过程中遇到的问题!

    技术2022-06-24  51

    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支持方面比微软更加灵活?呵呵。

     

     

     

     


    最新回复(0)