C primer plus笔记

这篇博客详细介绍了C语言中数据的表示方式,包括八进制、十六进制的表示,以及如何通过转换说明进行打印。文章还讨论了不同整型(如short、long、unsigned)的溢出行为,浮点型常量的精度和打印方法。此外,还提到了字符类型(char)的存储和打印,以及常用的转义序列和计数法。
摘要由CSDN通过智能技术生成

一.数据和C

1.八进制和十六进制

(1)C语言中都假定整形常量是十进制数

(2)Ox或OX前缀表示十六进制。例:十进制数16表示十六进制:Ox10或OX10

(3)O前缀表示八进制。例:十进制数16表示八进制:O20

(4)显示时需使用不同的转换说明。十进制:%d;八进制:%O;十六进制:%X(若要在显示时显示出O和OX前缀,需在转换说明中加入#。例:%#O,%#X)

(5)常用数据类关键字:

整形:short,long,int,unsigned,signed(注:除int歪的其他类型都为修饰int整形的变式,在使用时可省去int。unsigned表示无符号整形,值英语非负值的场合。signed表示有符号整形,在有符号类型的关键字钱添加signed可强调使用有符号类型的意图)

(6)long常量和long long常量:若遇到需将一个较小值以long,long long形式存储,在该值后加长LL(l也可用但可能与i(l)相混)。例:long:5L;long long:5LL;unsigned long long:5ULL,5LLU,5uLL,5LLu

(7)整数溢出:

有符号类型:超过最大值后,从最大值的负数-1开始计算。例如int,最大值为2 ^ 31 -1,即2147483647。当输入或存储的超过2 ^ 31后还要+1,2147483647 + 1 = -2147483648

无符号类型:超过最大值后从0开始。因为无符号类型没有正负概念。以int为例,无符号int的最大值为2 ^ 32 -1,即4294967295。当输入或存储的数超过这个值后+1,4294967295 + 1 = 0

(8)打印时所使用的转换说明(整形):

long:%ld;十六进制打印long:%lx;八进制打印long:%lo;long long:%lld

short:%hd;十六进制打印short:%hx;八进制打印short:%ho

unsigned int:%u;unsigned long:%lu;unsigned short:%hu;unsigned long long:%llu

(9)char类型:用于存储字符,但是是使用ASC||码等编码的形式来存储,因此可以看做是整数类型(char类型的初始化需永奥字符常量。例:char grade = 'A';)

char类型的打印(详见P47):打印整数,%d(打印的是给字符所对应的ASC||码);打印对应字符:%c;打印字符串:%s

(10)常用转义序列(P45)

(11)计数法(P49)

(12)浮点型常量:float:至少等表示6位有效数字;double,至少能表示6位有效数字;double,至少能表示10位有效数字(注:在编译器中,一般假定的浮点型常量为double类型,即float在计算式会议double类型进行计算,并将结果写成float类型。在浮点数后面甲f或F可以避免:2.3f;11E9F)

(13)浮点值打印:十进制计数法打印float和double:%f;指数计数法:%e;;long double类型:%lf,%le,%la(%xf可指定显示x位小数。例:%2f,显示到小数点后两位小数)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值