c primer plus(第六版) - 2 c语言概述 - 3 数据和C

本文介绍了C语言的语法和库,指出stdio并未内置到语法中,因并非所有程序都需要I/O。讨论了main()函数返回int给操作系统,解释了变量声明、转义字符和printf的用途。还涉及调试器、C关键字、数据类型、浮点数表示、编码系统、数据存储以及缓冲区的概念。

c语言包括“语法”和“库”,stdio并没有内置到“语法”中,为什么?因为并非所有程序都会用到I/O包

main()函数返回int,返回给谁?操作系统,参考第6章.... 现在是P42页

int num;  // num是“变量名”也称为标识符,“标识”某块内存的名称;

FORTRAN和BASIC的最初形式不必先声明变量,这样做的问题是,变量名在后面使用时,如果拼写错了,也不会报错!!

转义字符:\n回车,\b退格(但为什么有时候没用?)

问:printf为什么有f?

答:提醒用户,这是一种格式化打印函数

新工具:调试器:debugger

查询:c关键字:P54

量化方法描述编译器的工作:把1KB的源文件创建成60KB的可执行文件。

********************************************************************************************

第3章

c语言数据类型关键字查询:

 问:有没有long double?有!

_complex和_Imaginary分别表示复数虚数

字长对于64位计算机,字长位64.

浮点数在数学中被称为实数。书写浮点数有多种形式,如,e记数法。

复习:10的7次方,7被称为10的指数。

实例:7.0被写成0.7e1, 0.7是小数部分,1是指数部分,分别存储。存储实例如下:

 7.0可能被存储为浮点值6.99999。

题外话:有效位数:

如2.3590 有效位数5位(最后一位的0也要数)
0.0734 有效位数从第一个非零数(7)数起,共三位

题外话:现在CPU包含浮点处理器

P65注意:声明也会创建空间

8进制和16进制记数系统在表达与计算机相关的值时更方便。

16进制数每一位恰好由4位2进制数表示。和二进制之间的转换非常方便。

计算机如何知道10000是10进制、16进制还是2进制呢? 0x, 0

显示:%d, %o, %x,10进制,8进制,16进制;显示加0x等前缀,要写成%#o, %#x(冷知识

long long int或long long至少占64位,为什么引入long long?就是为了存储64位的整数

32位无符号整数,可以表示到42亿9千万多......

确定需要32位整数时,一般用long而非int,如果用int,当移植到16位机时,可能无法正常工作。

long long类型的后缀:LL

P70页

字符‘A’在计算机中怎么存储呢?存的也是数字,而不是字符,也就是说字符被编码成数字了。

美国最常用的是ASCII编码,字符‘A’被编码成65。IBM的EBCDIC编码中,‘A’被编码成0xC1。

ASCII码只有0~127,所以只用7位二进制就够了,剩余的一位有点浪费,于是IBM和APPLE提供了扩展ASCII码。问:哪家的扩展ASCII码是国际标准?

全球许多字符集都超过了255,汉字就有近10W,怎么编码?就算用16位(一般2个字节)也就只有0-65535。解决方法:商用的统一码(Unicode),目前已超过110000个。unicode是几位的?

unicode和utf8有什么区别?此外还有很多其它编码方式,都有什么关联性:

 问 char grade = 65; // 本意是赋为‘A’,会有问题吗?答:在ASCII编码中没问题,在EBCDIC中,grade可不是‘A’了。

char grade = ‘B’,在内存中存66,这应该存与32位中,现却存于8位中。那么char grade = 'FATE'时,grade的值是‘E’(最低的8位值)

非打印字符,有三种表示方法!

1)直接使用编码值,当然没问题:char beep = 7;

2)使用转义序列:查询:P72

最后这两个转义序列,表示用八进制十六进制表示字符

'\7', '\07', '\007'都是一样的。'\8'呢?

‘\x10’, '\x010'是一样的。

使用转移序列比使用ASCII码优先。‘\a’ 比 ‘\7’ 更容易知道是蜂鸣。

查询:查limits.h可以查到各种数据类型的取值范围

c99竟然定义c语言的bool类型为:_Bool,原则上只占1位存储空间!而不是8位!但sizeof应该还是1(个字节)。75页。

又没有保存,所以没有自动保存功能???

C的浮点类型有floatdoublelong doubleFORTRAN中只有一种real

科学记数法,指数记数法,这些名称记一下

float至少精确表示小数点后6位(记忆方法:lo合成6)有效数字,如33.333333。范围是10的正负37次方。float32位,8位表示指数和符号(所以指数占7?)

double至少13位有效数字?

冷知识:16进制浮点型常量:用p代替e,就变成了2的幂。例如0xa.1fp10,.1f是1/16加上15/256。

用%e打印指数记数法的浮点数

用%a打印16进制浮点数

用printf打印“上溢”,显示inf。

下溢:6位float 0.123456E-10,除以10,变成0.012345E-10,6没有了,称为下溢。

特殊的浮点值NaN(not a number)。正弦值不能大于1,如果传入的参数大于1,就是未定义行为,返回NaN。

若对精度外的数进行加减,计算结果是错误的P79实例。

查询:参考附录B.5,参考资料V

3种复数类型:float _Complex、double _Complex和long double _Complex。同理对应3种虚数_Imaginary类型。若包含“complex.h”(真有)头文件,则可以用complex代替_Complex。如果以前的代码中有结构体complex,就麻烦了。

在char类型为16,double类型为64位的系统中,sizeof给出的double是4字节

查询:limits.hfloat.h有类型限制的信息。

一些简单的命名约定:i_smart和us_versmart分别表示int和unsigned short

\b退格键的作用:可能不擦除前面的字符,而只是把光标往前移。

缓冲区buffer):

printf把输出发送到缓冲区,当缓冲区满遇到换行字符需要输入时,就发送到屏幕。

刷新缓冲区的另一种方法是调用fflush函数。

********************************************************************************************

第2章 遗留:

1)main()返回给os还没看

2)参考资料:VII:扩展字符支持,UCN,P738

第3章 遗留:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值