转自:http://blog.csdn.net/fivedoumi/article/details/7077504



d,lx,ld,,lu,这几个都是输出32位的

hd,hx,hu,这几个都是输出16位数据的,

hhd,hhx,hhu,这几个都是输出8位的,

lld,ll,llu,llx,这几个都是输出64位的,





printf( "%llu ",.....)

%llu   是64位无符号

%llx才是64位16进制数

 

Dev-C++下基本数据类型学习小结

环境: Dev-C++ 4.9.6.0 (gcc/mingw32), 使用-Wall编译选项

基本类型包括字节型(char)、整型(int)和浮点型(float/double)。

定义基本类型变量时,可以使用符号属性signed、unsigned(对于char、int),和长度属性short、long(对

于int、double)对变量的取值区间和精度进行说明。

下面列举了Dev-C++下基本类型所占位数和取值范围:

符号属性    长度属性    基本型    所占位数    取值范围      输入符举例     输出符举例

--           --         char        8        -2^7 ~2^7-1       %c         %c、%d、%u

signed       --         char        8        -2^7 ~2^7-1       %c         %c、%d、%u

unsigned     --         char        8        0 ~2^8-1          %c         %c、%d、%u

[signed]     short      [int]       16       -2^15 ~2^15-1             %hd

unsigned     short      [int]       16       0 ~2^16-1            %hu、%ho、%hx

[signed]     --          int        32       -2^31 ~2^31-1             %d

unsigned     --         [int]       32       0 ~2^32-1             %u、%o、%x

[signed]     long       [int]       32       -2^31 ~2^31-1             %ld

unsigned     long       [int]       32       0 ~2^32-1            %lu、%lo、%lx

[signed]     long long  [int]       64       -2^63 ~2^63-1            %I64d

unsigned     long long  [int]       64       0 ~2^64-1         %I64u、%I64o、%I64x

--           --         float       32      +/-3.40282e+038        %f、%e、%g

--           --         double      64      +/- 1.79769e+308 %lf、%le、%lg   %f、%e、%g

--           long       double      96      +/-1.79769e+308       %Lf、%Le、%Lg









几点说明:

1. 注意! 表中的每一行,代表一种基本类型。“[]”代表可省略。

例如:char、signed char、unsigned char是三种互不相同的类型;

int、short、long也是三种互不相同的类型。

可以使用C++的函数重载特性进行验证,如:

void Func(char ch) {}

void Func(signed char ch) {}

void Func(unsigned char ch) {}

是三个不同的函数。









2. char/signed char/unsigned char型数据长度为1字节;

char为有符号型,但与signed char是不同的类型。

注意! 并不是所有编译器都这样处理,char型数据长度不一定为1字节,char也不一定为有符号型。









3. 将char/signed char转换为int时,会对最高符号位1进行扩展,从而造成运算问题。

所以,如果要处理的数据中存在字节值大于127的情况,使用unsigned char较为妥当。

程序中若涉及位运算,也应该使用unsigned型变量。









4. char/signed char/unsigned char输出时,使用格式符%c(按字符方式);

或使用%d、%u、%x/%X、%o,按整数方式输出;

输入时,应使用%c,若使用整数方式,Dev-C++会给出警告,不建议这样使用。









5. int的长度,是16位还是32位,与编译器字长有关。

16位编译器(如TC使用的编译器)下,int为16位;32位编译器(如VC使用的编译器cl.exe)下,int为32

位。

6. 整型数据可以使用%d(有符号10进制)、%o(无符号8进制)或%x/%X(无符号16进制)方式输入输出。

而格式符%u,表示unsigned,即无符号10进制方式。









7. 整型前缀h表示short,l表示long。

输入输出short/unsigned short时,不建议直接使用int的格式符%d/%u等,要加前缀h。

这个习惯性错误,来源于TC。TC下,int的长度和默认符号属性,都与short一致,

于是就把这两种类型当成是相同的,都用int方式进行输入输出。









8. 关于long long类型的输入输出:

"%lld"和"%llu"是linux下gcc/g++用于long long int类型(64bits)输入输出的格式符。

而"%I64d"和"%I64u"则是Microsoft VC++库里用于输入输出__int64类型的格式说明。

Dev-C++使用的编译器是Mingw32,Mingw32是x86-win32gcc子项目之一,编译器核心还是linux下的gcc。

进行函数参数类型检查的是在编译阶段,gcc编译器对格式字符串进行检查,显然它不认得"%I64d",

所以将给出警告“unknown conversion type character `I' informat”。对于"%lld"和"%llu",gcc理

所当然地接受了。

Mingw32在编译期间使用gcc的规则检查语法,在连接和运行时使用的却是Microsoft库。

这个库里的printf和scanf函数当然不认识linuxgcc下"%lld"和"%llu",但对"%I64d"和"%I64u",它则是

乐意接受,并能正常工作的。









9. 浮点型数据输入时可使用%f、%e/%E或%g/%G,scanf会根据输入数据形式,自动处理。

输出时可使用%f(普通方式)、%e/%E(指数方式)或%g/%G(自动选择)。









10. 浮点参数压栈的规则:float(4 字节)类型扩展成double(8 字节)入栈。

C 打印格式小记的更多相关文章

  1. 在sap系统设置纸张打印格式(针式打印机)

    在sap做一个打印报表,要先设置一个纸张打印格式,下面以工厂中常用来打印的针孔纸为例,在sap设置该纸张的打印格式,以用于报表: 1.运行事务代码SPAD:选择工具栏上的[完全管理]按钮——>选 ...

  2. Android打印机--小票打印格式及模板设置

    小票打印就是向打印设备发送控制打印格式的指令集,而这些打印格式须要去查询相应打印机的API文档,这里我把经常使用的api给封装了一下 文字对齐方式 打印字体大小 字体是否加粗 打印二维码 打印条形码 ...

  3. Smartforms 设置纸张打印格式

    在sap做一个打印报表,要先设置一个纸张打印格式,下面以工厂中常用来打印的针孔纸为例,在sap设置该纸张的打印格式,以用于报表: 1.运行事务代码SPAD:选择工具栏上的[完全管理]按钮——>选 ...

  4. print,cat打印格式及字符串引号格式,去掉字符串空格 in R

    print 函数的打印格式: ##no quote print out > x <- letters[1:5] > print(x,quote=F,);print(x,quote=T ...

  5. 【ABAP系列】SAP Smartforms 设置纸张打印格式

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP Smartforms 设 ...

  6. 关于str的打印格式

    实际上一般的打印格式应该是这样的: %[(keyname)][flags][width][.precision]typecode (1) keyname: 用于打印Dict类型时做索引; (2) fl ...

  7. c 中打印格式%g

    C语言中打印float或double类型最常用的是%f格式,最近看书时看到有使用%g格式打印. %f  表示按浮点数的格式打印. 小数点后固定6位 %e 表示以指数形式的浮点数格式输出. %g 表示自 ...

  8. SMARTFORMS自定义打印格式

    [转自 http://lz357502668.blog.163.com/blog/static/16496743201272155135570/] 在sap的打印开发中经常需要自定义纸张,具体步骤如下 ...

  9. 3D打印格式STL

    STL格式及其转换 近期接触了3D打印的一些东西,也制作了一个vrml转stl的插件,对该领域多了一些认识. 目前尚没有打印机直接支持stl.obj等格式,在打印之前需使用厂家提供的软件将stl等格式 ...

随机推荐

  1. DragVideo,一种在播放视频时,可以任意拖拽的方案

    转载请把头部出处链接和尾部二维码一起转载,本文出自逆流的鱼yuiop:http://blog.csdn.net/hejjunlin/article/details/53638896 前言 项目已开源到 ...

  2. 不可错过的Node.js框架

    前言 Node.js是由Ryan Dahl于2009年创建的.它是一个开源的跨平台运行时环境,用于开发服务器端和网络应用程序,它是基于Google Chrome V8 JavaScript引擎构建的. ...

  3. 给定一数组,输出满足2a=b(a,b代表数组中的数)的数对,要求时间复杂度尽量低。

    //时间复杂度O(n),空间复杂度O(n) void findSequence(int* arr, int len) { int* hashtable = new int[RANGE]; memset ...

  4. ORACLE数据库管理常用查询语句

    /*查看表空间的名称及大小*/ SELECT t.tablespace_name, round(SUM(bytes / (1024 * 1024)), 0) ts_size FROM dba_tabl ...

  5. 百度map 3.0初探

    1.简介 在使用百度地图SDK为您提供的各种LBS能力之前,您需要获取百度地图移动版的开发密钥,该密钥与您的百度账户相关联.因此,您必须先有百度帐户,才能获得开发密钥.并且,该密钥与您创建的过程名称有 ...

  6. FFmpeg源代码简单分析:libavdevice的gdigrab

    ===================================================== FFmpeg的库函数源代码分析文章列表: [架构图] FFmpeg源代码结构图 - 解码 F ...

  7. 文件操作(File类等)API摘要

    Console 此类包含多个方法,可访问与当前 Java 虚拟机关联的基于字符的控制台设备(如果有). 虚拟机是否具有控制台取决于底层平台,还取决于调用虚拟机的方式.如果虚拟机从一个交互式命令行开始启 ...

  8. (NO.00004)iOS实现打砖块游戏(十五):导弹发射道具的实现(上)

    大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请告诉我,如果觉得不错请多多支持点赞.谢谢! hopy ;) 上一篇中我们实现了3球道具,但是好像还是不过瘾,如果能让反弹棒更 ...

  9. java虚拟机工具入门

    jps 能显示现在都有那些java程序运行 C:\Users\Administrator>jps 16964 DeadLockJstack 9172 PULSEI~1.JAR 19392 Jps ...

  10. Dynamics CRM2013 注释中的内容无法正常显示问题

    CRM2013中在表单中插入注释,并把注释设置成默认选项卡后 打开一个已经挂了附件的表单,但却显示找不到记录 必须要再点击下注释,内容才会出来 查了半天不得其解,终于在ur1 for CRM2013  ...