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的浮点类型有float,double和long double,FORTRAN中只有一种real?
科学记数法,指数记数法,这些名称记一下
float至少精确表示小数点后6位(记忆方法:lo合成6)有效数字,如33.333333。范围是10的正负37次方。float共32位,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.h和float.h有类型限制的信息。
一些简单的命名约定:i_smart和us_versmart分别表示int和unsigned short
\b退格键的作用:可能不擦除前面的字符,而只是把光标往前移。
缓冲区(buffer):
printf把输出发送到缓冲区,当缓冲区满,遇到换行字符或需要输入时,就发送到屏幕。
刷新缓冲区的另一种方法是调用fflush函数。
********************************************************************************************
第2章 遗留:
1)main()返回给os还没看
2)参考资料:VII:扩展字符支持,UCN,P738
第3章 遗留:
本文介绍了C语言的语法和库,指出stdio并未内置到语法中,因并非所有程序都需要I/O。讨论了main()函数返回int给操作系统,解释了变量声明、转义字符和printf的用途。还涉及调试器、C关键字、数据类型、浮点数表示、编码系统、数据存储以及缓冲区的概念。
1061

被折叠的 条评论
为什么被折叠?



