热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

C/C++的64位整型不同编译器间的比较

为了和DSP兼容,TSint64和TUint64设置成TSint40和TUint40一样的数结果VC中还是认为是32位的,显然不合适typedefsig


  1. //为了和DSP兼容,TSint64和TUint64设置成TSint40和TUint40一样的数
  2. //结果VC中还是认为是32位的,显然不合适
  3. //typedefsignedlongintTSint64;
  4. //typedefunsignedlongintTUint64;
  5. //ANSIC中规定longlong才能表示64位
  6. //参见:http://msdn.microsoft.com/en-us/library/s3f49ktz.aspx
  7. //可惜VC++6.0不认识longlong,会报errorC2632:'long'followedby'long'isillegal
  8. typedefsignedlonglongTSint64;//It'sillegalinC90.It'slegelinC99.
  9. typedefunsignedlonglongTUint64;
  10. //typedefLONGLONGTSint64;//VC不认
  11. //typedefULONGLONGTUint64;

zz fromhttp://www.byvoid.com/blog/c-int64/

在C/C&#43;&#43;中&#xff0c;64为整型一直是一种没有确定规范的数据类型。现今主流的编译器中&#xff0c;对64为整型的支持也是标准不一&#xff0c;形态各异。一般来说&#xff0c;64位整型的定义方式有long long和__int64两种(VC还支持_int64)&#xff0c;而输出到标准输出方式有printf(“%lld”,a)&#xff0c;printf(“%I64d”,a)&#xff0c;和cout <

本文讨论的是五种常用的C/C&#43;&#43;编译器对64位整型的支持&#xff0c;这五种编译器分别是gcc(mingw32)&#xff0c;g&#43;&#43;(mingw32)&#xff0c;gcc(linux i386)&#xff0c;g&#43;&#43;(linux i386)&#xff0c;Microsoft Visual C&#43;&#43; 6.0。可惜的是&#xff0c;没有一种定义和输出方式组合&#xff0c;同时兼容这五种编译器。为彻底弄清不同编译器对64位整型&#xff0c;我写了程序对它们进行了评测&#xff0c;结果如下表。

变量定义输出方式gcc(mingw32)g&#43;&#43;(mingw32)gcc(linux i386)g&#43;&#43;(linux i386)MicrosoftVisual C&#43;&#43; 6.0
long long“%lld”错误错误正确正确无法编译
long long“%I64d”正确正确错误错误无法编译
__int64“lld”错误错误无法编译无法编译错误
__int64“%I64d”正确正确无法编译无法编译正确
long longcout非C&#43;&#43;正确非C&#43;&#43;正确无法编译
__int64cout非C&#43;&#43;正确非C&#43;&#43;无法编译无法编译
long longprintint64()正确正确正确正确无法编译

上表中&#xff0c;正确指编译通过&#xff0c;运行完全正确&#xff1b;错误指编译虽然通过&#xff0c;但运行结果有误&#xff1b;无法编译指编译器根本不能编译完成。观察上表&#xff0c;我们可以发现以下几点&#xff1a;

  1. long long定义方式可以用于gcc/g&#43;&#43;&#xff0c;不受平台限制&#xff0c;但不能用于VC6.0。
  2. __int64是Win32平台编译器64位长整型的定义方式&#xff0c;不能用于Linux。
  3. “%lld”用于Linux i386平台编译器&#xff0c;”%I64d”用于Win32平台编译器。
  4. cout只能用于C&#43;&#43;编译&#xff0c;在VC6.0中&#xff0c;cout不支持64位长整型。

表中最后一行输出方式中的printint64()是我自己写的一个函数&#xff0c;可以看出&#xff0c;它的兼容性要好于其他所有的输出方式&#xff0c;它是一段这样的代码&#xff1a;

  1. voidprintint64(longlonga)
  2. {
  3. if(a<&#61;100000000)
  4. printf("%d/n",a);
  5. else
  6. {
  7. printf("%d",a/100000000);
  8. printf("%08d/n",a%100000000);
  9. }
  10. }

这种写法的本质是把较大的64位整型拆分为两个32位整型&#xff0c;然后依次输出&#xff0c;低位的部分要补0。看似很笨的写法&#xff0c;效果如何&#xff1f;我把它和cout输出方式做了比较&#xff0c;因为它和cout都是C&#43;&#43;支持跨平台的。首先printint64()和cout(不清空缓冲区)的运行结果是完全相同的&#xff0c;不会出现错误。我的试验是分别用两者输出1000000个随机数&#xff0c;实际结果是&#xff0c;printint64()在1.5s内跑完了程序&#xff0c;而cout需要2s。cout要稍慢一些&#xff0c;所以在输出大量数据时&#xff0c;要尽量避免使用。

zz fromhttp://blog.csdn.net/zhlynn/archive/2009/03/28/4032152.aspx

64位整数全解(增补板)

64位整形引起的混乱主要在两方面&#xff0c;一是数据类型的声明&#xff0c;二是输入输出。

首先是如果我们在自己机器上写程序的话&#xff0c;情况分类如下&#xff1a;

(1) 在win下的VC6.0里面&#xff0c;声明数据类型的时候应该写作

__int64 a;

输入输出的时候用 %I64d

scanf(”%I64d”,&a);
printf(”%I64d”,a);

(2) 在linux下的gcc/g&#43;&#43;里面&#xff0c;数据类型声明写作

long long a;

输入输出时候用 %lld

(3) 在win下的其它IDE里面[包括高版本Visual Studio]&#xff0c;数据类型声明用上面两种均可

输入输出用 %I64d

&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61; 以下可无视 &#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;

以下是对这种混乱情况的解释&#xff0c;如无兴趣可以跳过

首先要说的是&#xff0c;和Java等语言不同&#xff0c;C/C&#43;&#43;本身并没有规定各数据类型的位数&#xff0c;只是限定了一个大小关系&#xff0c;也就是规定从所占的bit数来说&#xff0c;short <&#61; int <&#61; long <&#61; long long。至于具体哪种类型占用多少位&#xff0c;是由你所用的开发平台的编译器决定的。在现在的PC上一个通常的标准是&#xff0c;int和long同为32位&#xff0c;long long为64位。但是如果换到其它平台(如ARM)上&#xff0c;这个数字可能会有不同&#xff0c;类型所占的大小可以用sizeof()运算符查看。

long long是C99标准中新引进的数据类型&#xff0c;在古老的VC6.0中并没有这个类型&#xff0c;所以在VC6.0中用”long long”会发生编译错误。为了表示64位整数&#xff0c;VC6里采用的是微软自己搞出来的一个数据类型&#xff0c;叫做__int64&#xff0c;所以如果你是在VC6.0下编译的话&#xff0c;应该用__int64定义64位整型。新版的Visual Studio已经支持long long了。GCC是支持long long的&#xff0c;我们在win系统中使用的其它IDE如Dev-Cpp, Code::Blocks等等大多是采用的MinGW编译环境&#xff0c;它是与GCC兼容的&#xff0c;所以也支持long long&#xff08;另外为了与MS兼容&#xff0c;也支持__int64&#xff09;。如果是在纯的linux下&#xff0c;就只能使用long long了。

关于使用printf的输入输出&#xff0c;这里就有一个更囧的情况。实际上只要记住&#xff0c;主要的区分在于操作系统&#xff1a;如果在win系统下&#xff0c;那么无论什么编译器&#xff0c;一律用%I64d&#xff1b;如果在linux系统&#xff0c;一律用%lld。这是因为MS提供的msvcrt.dll库里使用的就是%I64d的方式&#xff0c;尽管Dev-Cpp等在语法上支持标准&#xff0c;但也不得不使用MS提供的dll库来完成IO&#xff0c;所以就造成了这种情况。

&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61; 无视至此 &#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;

那么对ACMer来说&#xff0c;最为关心的就是在各个OJ上交题应分别使用哪种方式了。其实方式只有有限的几种&#xff1a;

如果服务器是linux系统&#xff0c;那么定义用long long&#xff0c;IO用%lld
如果服务器是win系统&#xff0c;那么声明要针对编译器而定&#xff1a;
&#43; 如果用MS系列编译器&#xff0c;声明用__int64 [现在新版的Visual Studio也支持long long了]
&#43; 如果用MinGW环境&#xff0c;声明用long long
&#43; 无论什么编译器&#xff0c;IO一律%I64d

下面把各大OJ情况列表如下&#xff1a;

1. TOJ : Linux系统
2. ZOJ : Linux系统
3. POJ : Win系统&#xff0c;语言如选择C/C&#43;&#43;&#xff0c;则用MS编译器[支持两种声明]&#xff0c;如选择GCC/G&#43;&#43;&#xff0c;则为MinGW
4. UVa : Linux系统
5. Ural: Win系统&#xff0c;MS编译器[支持两种声明]
6. SPOJ: Linux系统
7. SGU : Win系统&#xff0c;MS编译器[支持两种声明]

如果有不太清楚的情况可以先看看各OJ上的FAQ&#xff0c;通常会有说明。

另外&#xff0c;为了避免混乱&#xff0c;当数据量不大时&#xff0c;用cin, cout进行输入输出也是一种选择



推荐阅读
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 使用Python在SAE上开发新浪微博应用的初步探索
    最近重新审视了新浪云平台(SAE)提供的服务,发现其已支持Python开发。本文将详细介绍如何利用Django框架构建一个简单的新浪微博应用,并分享开发过程中的关键步骤。 ... [详细]
  • 本文详细介绍如何使用arm-eabi-gdb调试Android平台上的C/C++程序。通过具体步骤和实用技巧,帮助开发者更高效地进行调试工作。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 深入解析Spring Cloud Ribbon负载均衡机制
    本文详细介绍了Spring Cloud中的Ribbon组件如何实现服务调用的负载均衡。通过分析其工作原理、源码结构及配置方式,帮助读者理解Ribbon在分布式系统中的重要作用。 ... [详细]
  • DNN Community 和 Professional 版本的主要差异
    本文详细解析了 DotNetNuke (DNN) 的两种主要版本:Community 和 Professional。通过对比两者的功能和附加组件,帮助用户选择最适合其需求的版本。 ... [详细]
  • 在当前众多持久层框架中,MyBatis(前身为iBatis)凭借其轻量级、易用性和对SQL的直接支持,成为许多开发者的首选。本文将详细探讨MyBatis的核心概念、设计理念及其优势。 ... [详细]
  • XNA 3.0 游戏编程:从 XML 文件加载数据
    本文介绍如何在 XNA 3.0 游戏项目中从 XML 文件加载数据。我们将探讨如何将 XML 数据序列化为二进制文件,并通过内容管道加载到游戏中。此外,还会涉及自定义类型读取器和写入器的实现。 ... [详细]
  • 360SRC安全应急响应:从漏洞提交到修复的全过程
    本文详细介绍了360SRC平台处理一起关键安全事件的过程,涵盖从漏洞提交、验证、排查到最终修复的各个环节。通过这一案例,展示了360在安全应急响应方面的专业能力和严谨态度。 ... [详细]
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
  • 本文详细分析了Hive在启动过程中遇到的权限拒绝错误,并提供了多种解决方案,包括调整文件权限、用户组设置以及环境变量配置等。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 深入理解Java泛型:JDK 5的新特性
    本文详细介绍了Java泛型的概念及其在JDK 5中的应用,通过具体代码示例解释了泛型的引入、作用和优势。同时,探讨了泛型类、泛型方法和泛型接口的实现,并深入讲解了通配符的使用。 ... [详细]
  • libsodium 1.0.15 发布:引入重大不兼容更新
    最新发布的 libsodium 1.0.15 版本带来了若干不兼容的变更,其中包括默认密码散列算法的更改和其他重要调整。 ... [详细]
author-avatar
love四叶草health
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有