1、C语⾔数据类型和变量
1、使⽤整型类型(int)来描述整数,使⽤字符类型(char)来描述字符,使⽤浮点型类型(float、double)来描述⼩数,布尔类型(_Bool)表示真假(1表示真,0表示假)
2、C语⾔使⽤ signed 和 unsigned 关键字修饰字符型和整型类型的,signed 关键字,表⽰⼀个类型带有正负号,包含负值; unsigned 关键字,表⽰该类型不带有正负号,只能表⽰零和正整数。
3、对于 int 类型,默认是带有正负号的,也就是说 由于这是默认情况,关键字 int 等同于 signed int,整数变量声明为 unsigned 的好处是,同样⻓度的内存能够表⽰的最⼤整数值,增⼤了⼀倍。 ⽐如,16位的 signed short int 的取值范围是:-32768~32767,最⼤是32767;⽽ unsigned short int 的取值范围是:0~65535,最⼤值增⼤到了65,535
4、数据类型的取值范围
• S CHAR_MIN , SCHAR_MAX :signedchar的最⼩值和最⼤值。
• SH RT_MIN , SHRT_MAX :short的最⼩值和最⼤值。
• IN T_MIN , INT_MAX :int的最⼩值和最⼤值。
• LO NG_MIN , LONG_MAX :long的最⼩值和最⼤值。
• L LONG_MIN , LLONG_MAX :longlong的最⼩值和最⼤值。
• U CHAR_MAX :unsignedchar的最⼤值。
• U SHRT_MAX :unsignedshort的最⼤值。
• UI NT_MAX :unsignedint的最⼤值。
• U LONG_MAX :unsignedlong的最⼤值。
• U LLONG_MAX :unsignedlonglong的最⼤值。
5、sizeof 是⼀个关键字,也是操作符,专⻔是⽤来计算sizeof的操作符数的类型⻓度的,单位是字 节,sizeof 运算符的返回值,并没有规定具体的类型,⽽是留给系统⾃⼰去决定
sizeof( 类型 )
sizeof 表达式
5、C语⾔中把经常变化的值称为变量,不变的值称为常量
初始化:变量在创建的时候就给⼀个初始值
全局变量:在⼤括号外部定义的变量就是全局变量 全局变量的使⽤范围更⼴
局部变量:在⼤括号内部定义的变量就是局部变量
6、算术运算符(双目操作符)
+ - * / % ,这些操作符都是双⽬操作符
运算符+ 和 - ⽤来完成加法和减法:
运算符 * ⽤来完成乘法:
运算符 / ⽤来完成除法:
C语⾔⾥⾯的整数除法是整除,只会返回整数部分,丢弃⼩数部分,如果希望得到浮点数的结果,两个运算数必须⾄少有⼀个浮点数,这时C语⾔就会进⾏浮点数除法
运算符 % 表⽰求模运算,即返回两个整数相除的余值。这个运算符只能⽤于整数,不能⽤于浮点数,负数求模的规则是,结果的正负号由第⼀个运算数的正负号决定:
7、复合赋值符
C语⾔中提供了复合赋值符,⽅便我们编写代码,这些赋值符有:
1 += -= *= /= >>= &= <<= |= %= ^=
等于
8、单⽬操作符:++、--、+、-
前置++:先+1,后使⽤
后置++:先使⽤,后+1
前置--:先-1,后使⽤
后置:先使⽤,后-1
9、强制类型转换
int a = (int) 3.14
10、printf()占位符列举
printf() 的占位符有许多种类,与C语⾔的数据类型相对应。下⾯按照字⺟顺序,列出常⽤的占位 符,⽅便查找,具体含义在后⾯章节介绍。
• %a :⼗六进制浮点数,字⺟输出为⼩写。
• %A :⼗六进制浮点数,字⺟输出为⼤写。
• %c :字符。 • %d :⼗进制整数。
• %e :使⽤科学计数法的浮点数,指数部分的 e 为⼩写。
• %E :使⽤科学计数法的浮点数,指数部分的 E 为⼤写。
• %i :整数,基本等同于 %d 。
• %f :⼩数(包含 float 类型和 double 类型)。
• %g :6个有效数字的浮点数。整数部分⼀旦超过6位,就会⾃动转为科学计数法,指数部分的 e 为⼩写。
• %G :等同于 %g ,唯⼀的区别是指数部分的 E 为⼤写。
• %hd :⼗进制shortint类型。
• %ho :⼋进制shortint类型。
• %hx :⼗六进制shortint类型。
• %hu :unsignedshortint类型。
• %ld :⼗进制longint类型。
• %lo :⼋进制longint类型。
• %lx :⼗六进制longint类型。
• %lu :unsignedlongint类型。
• %lld :⼗进制longlongint类型。
• %llo :⼋进制longlongint类型。
• %llx :⼗六进制longlongint类型。
• %llu :unsignedlonglongint类型。
• %Le :科学计数法表⽰的longdouble类型浮点数。
• %Lf :longdouble类型浮点数。
• %n :已输出的字符串数量。该占位符本⾝不输出,只将值存储在指定变量之中。
• %o :⼋进制整数。
• %p :指针。
• %s :字符串。
• %u :⽆符号整数(unsignedint)。
• %x :⼗六进制整数。
• %zd : size_t 类型。
• %% :输出⼀个百分号。
例:%5d 表⽰这个占位符的宽度⾄少为5位。如果不满5位,对应的值的前⾯会添加空格。 输出的值默认是右对⻬,即输出内容前⾯会有空格;如果希望改成左对⻬,在输出内容后⾯添加空格,可以在占位符的 % 的后⾯插⼊⼀个 - 号
默认情况下, printf() 不对正数显⽰ + 号,只对负数显⽰ -号。如果想让正数也输出 + 号,可 以在占位符的 % 后⾯加⼀个 +
输出⼩数时,有时希望限定⼩数的位数。举例来说,希望⼩数点后⾯只保留两位,占位符可以写 成 %.2f
%s 占位符⽤来输出字符串,默认是全部输出。如果只想输出开头的部分,可以⽤ 的⻓度,其中 [m] 代表⼀个数字,表⽰所要输出的⻓度
11、scanf()输入,printf()输出
scanf()传递的不是值,而是地址,所以变量前面要加&,指针变量除外
scanf() 处理数值占位符时,会⾃动过滤空⽩字符,包括空格、制表符、换⾏符等, 所以,⽤⼾输⼊的数据之间,有⼀个或多个空格不影响 scanf() 解读数据另外,⽤户使⽤回⻋ 键,将输⼊分成⼏⾏,也不影响解读
如果没有读取任何项,或者匹配失败,则返回 0 。如果在成功读取任何数据之前,发⽣了读取错误或 者遇到读取到⽂件结尾,则返回常量EOF
12、scanf()占位符
scanf() 常⽤的占位符如下
• %c :字符。
• %d :整数。
• %f : float 类型浮点数。
• %lf : double 类型浮点数。
• %Lf : long double 类型浮点数。
• %s :字符串。
• %[] :在⽅括号中指定⼀组匹配的字符((⽐如 %[0-9])
上⾯所有占位符之中,除了 %c 以外,都会⾃动忽略起⾸的空⽩字符。 回当前第⼀个字符,⽆论该字符是否为空格。 如果要强制跳过字符前的空⽩字符,可以写成 %c 不忽略空⽩字符,总是返 scanf(" %c", &ch) ,即 %c 前加上⼀个空格,表 ⽰跳过零个或多个空⽩字符。
13、赋值忽略符
只要把 * 加在任何占位符的百分号后⾯,该占位符就不会返回值,解析后将被丢弃,%*c 就是在占位符的百分号后⾯,加⼊了赋值忽略符 * ,表⽰这个占位符没有对应的 变量,解读后不必返回