起源与概括
1973年,为了Unix系统,贝尔实验室发明。标准化两个:C89(也就是ISO C90)和C99。C语系有:C++、Java、perl、C#等。特点:底层(与硬件接触)、小型(有限的语言特性;依赖标准函数库)、包容性等。
主函数main函数有且只能有一个,c89默认返回值是int,c99中规定必须写成int man()相对应有了return 0。用/* */注释的时候,系统会自动从/*开始,遇到下一个*/结束,所以中间出现*是没有问题的(引申各种格式的注释,包括盒子一样的)。
五大类型:基本数据类型、构造数据类型、指针类型、空、自定义类型。
三大结构:顺序结构、选择结构、循环结构。
位操作
&按位与,|或,~取反,^异或,<<左移,>>右移
位操作都是针对二进制进行,假设原来的数为a,取反相当于-1-a,移动如a<<n,左移n位。移动时,低位补0,高位移出。
应用:数据交换、异或实现文件加密(一次加密,二次解密)。
变量与字符
变量是内存中的一片空间,有名字及类型,类型决定了变量在内存中空间的大小,名称可以是字母、数字和下划线的组合,开头第一个字符不能是数字。且不能是C中的关键词,如int、if、struct之类,C中区分大小写,如是INT等就可以。定义(类型 名称)→赋值(assign,赋值符=)。
基本类型:
计算机基本的计算单位是字节(Bytes),每个字节是8个二进制的位(bit)。
1. 整型与字符型
除了整型外,其余定义的时候,int可以省略,如 long long a。unsigned开头的,代表无符号,即非负,里面所有的d替换成u进行输入输出。如果要显示02这种格式,可以用%.2d,如果没有小数点,输出的会有两个字符,但其中一个是空格,%-表示左对齐。
整数在实际保存的时候,是按照二进制保存。但赋值的时候有三种方式:十进制(平时的写法)、八进制(数字0开头)和十六进制(0x开头)。在输出时:十进制是d,八进制是#o,十六进制是#x(如果是X,表示输入或者输出的时候,里面的字母是大写的),#表示显示前缀,没有则不显示。
char字符型,单个字符(1个字节),包括字母单个数字空格等字符。ASCII码中,’A’的编码是65,’a’是97。中文字符是字符串,10也已经是字符串了(所以之前看到的一个定义纸牌上从A到K,用的是二维数组而不是一维)。
2. 浮点型
可以用科学计数法表示数据浮点数,永远无法精确表示。float是四个字节,double是八个,long double是16个。
%g用来输出实数,它根据数值的大小,自动选f格式或e格式(选择输出时占宽度较小的一种),且不输出无意义的0。即%g是根据结果自动选择科学记数法还是一般的小数记数法。%f默认保留6位小数,要制定保留的小数位数,用%.nf,n为要保留的位数。
注意,a=.123, b=5e6是有意义的赋值语句。另外,scanf函数会跳过空白字符(white-space,包括空格、横向和纵向制表符、换页符和换行符)根据格式来匹配读数。
备注(C的32个关键词,我按照自己的方式分了个类, 注意,main不是关键词):
int, long, short, unsigned, signed, float, double, char, void, struct, union, enum, typedef, sizeof
if, else, do, while, switch, case, default, break, continue, goto, for, return
auto, extern, static, register, const, volatile
特殊字符
\n换行 \r回车(本行的行首) \t制表符(若干空格) \b退格符 \转义符 %占位符 &取地址符
\转义符:特殊符号的打印如双引号”、斜线,在前面加上\,百分号打印的时候是%%
%叫做占位符,在标准化输入输出的时候,会先预留空间,用后面的来替换。
scanf(“%*[^\n]”);从输入缓冲区清空一行内容(%*指跳过,后面的是指非换行符,即一直跳过直到遇到换行符\n)
类型强转换
C语言是弱类型的,类型不同的运算会先转换成相同的类型再进行。在使用强制转换时应注意以下问题:
1、类型说明符和表达式都必须加括号,如把(int)(x/2+y)写成(int)x/2+y则成了把x/2转换成int型之后再与y相加了。
2、转换后不会改变原数据的类型及变量值,只在本次运算中临时转换。
3、强制转换后的运算结果不遵循四舍五入原则。
局部变量(local variable)和外部变量(即全局变量external variable)
函数中,一般是局部变量,static静态存储,只能赋值一次,程序执行返回,不会丢失值。全局变量也有静态存储期限,且在文件中的作用域从变量声明到闭合文件的末尾。
运算符(Operator)
优先级最高的是(),最低的是赋值符号=(包括了*=、+=、-=、/=、%=,但不包括自增++和自减--)。单目(正负号、自增自减、非)的优先级大于双目(四则运算、大小比较、等于不等于、且或)大于三目(条件判断?是:不是)。
对于模运算,即取余%,该运算只适合用两个整数进行取余运算,且最后的结果取决于%前面的数,即取决于被模数的符号。
对于除法运算/,结果和参与运算的数类型相同,所以9/2会只得到整数部分4,float就可以得到结果。两数中有一个为小数,结果则为小数,如:9.0/2 = 4.500000。
比较运算的结果是逻辑值,结果为0或者1,逻辑运算符可以简写,如&&写成&,||写成|,但写两个运算效率高些——因为在&&的情况下,有短路特性,即如果已经得知结果,不会去继续。
自增自减运算符,a++先参与运算后+1,++a先+1后参与运算。(这里面包括输出函数中的情况,但有时候例如a+++a+++a++这种,结果取决于编译器)
赋值运算的时候,左值不能是常数、字面值(字符串等)和临时值(如a+b)。