C语言二进制、八进制、十六进制整数书写和输出
2021-02-04 07:17
标签:nim 编写 读者 字符串 不能 oss ref 现在 image 在定义变量的时候,可以加signed、unsigned、short和long四种修饰符。 signed:有符号的,可以表示正数和负数。 unsigned:无符号的,只能表示正数,例如数组的下标、人的身高等。 short:短的,现在主流的64位操作系统下,整数占用内存4个字节,使用 4 long:长的,更长的整数。 一个数字默认就是十进制的,表示一个十进制数字不需要任何特殊的格式。但是,表示一个二进制、八进制或者十六进制数字就不一样了,为了和十进制数字区分开来,必须采用某种特殊的写法,具体来说,就是在数字前面加上特定的字符,也就是加前缀。 二进制由 0 和 1 两个数字组成,使用时必须以0b或0B(不区分大小写)开头。 以下是合法的二进制: 以下是非法的二进制: 请注意,标准的C语言并不支持上面的二进制写法,只是有些编译器自己进行了扩展,才支持二进制数字。换句话说,并不是所有的编译器都支持二进制数字,只有一部分编译器支持,并且跟编译器的版本有关系。 八进制由 0\~7 八个数字组成,使用时必须以0开头(注意是数字 0,不是字母 o)。 以下是合法的八进制数: 以下是非法的八进制: 十六进制由数字 0\~9、字母 A\~F 或a\~f(不区分大小写)组成,使用时必须以0x或0X(不区分大小写)开头。 以下是合法的十六进制: 以下是非法的十六进制: 在现实生活和工作中,我们在写十进制数的时候,为了对齐或其它原因,在数值前面加0是无关紧要的,但是,在C语言中,不要在十进制数前加0,会被计算机误认为是八进制数。 下表是各种进制整数的输出格式。 细心的读者可能会发现,上表中没有二进制的输出格式,虽然部分编译器支持二进制数字的书写,但是却不能使用printf函数输出二进制数。您可以编写函数把其它进制数字转换成二进制数字,并保存在字符串中,然后在printf 函数中使用%s输出。 示例: C语言技术网原创文章,转载请说明文章的来源、作者和原文的链接。 来源:C语言技术网(www.freecplus.net) 作者:码农有道 如果这篇文章对您有帮助,请点赞支持,或在您的博客中转发此文,让更多的人可以看到它,谢谢!!! C语言二进制、八进制、十六进制整数书写和输出 标签:nim 编写 读者 字符串 不能 oss ref 现在 image 原文地址:https://blog.51cto.com/14793471/2491250
个字节保存较小的整数绰绰有余,会空闲出两个字节来,这些字节就白白浪费掉了。在C语言被发明的早期,或者在单片机和嵌入式系统中,内存都是非常稀缺的资源,所有的程序都在尽可能节省内存。一、二进制、八进制、十六进制整数的书写
1、二进制
int a = 0b101; // 换算成十进制为 5
int b = -0b110010; // 换算成十进制为 -50
int c = 0B100001; // 换算成十进制为 33
int m = 101010; // 无前缀 0B,相当于十进制
int n = 0B410; // 4不是有效的二进制数字
2、八进制
int a = 015; // 换算成十进制为 13
int b = -0101; // 换算成十进制为 -65
int c = 0177777; // 换算成十进制为 65535
int m = 256; // 无前缀 0,相当于十进制
int n = 03A2; // A不是有效的八进制数字
3、十六进制
int a = 0X2A; // 换算成十进制为 42
int b = -0XA0; // 换算成十进制为 -160
int c = 0xffff; // 换算成十进制为 65535
int m = 5A; // 没有前缀 0X,是一个无效数字
int n = 0X3H; // H不是有效的十六进制数字
4、需要注意的坑
二、二进制、八进制、十六进制整数的输出
/*
* 程序名:book.c,此程序用于演示二进制、八进制、十六进制整数的输出。
* 作者:C语言技术网(www.freecplus.net) 日期:20190525。
*/
#include
四、版权声明
下一篇:C语言把整数转换为字符串