学习C语言第二次总结

本文详细介绍了C语言中的数据类型(如整型、字符型、浮点型和布尔型),以及它们的signed和unsigned修饰符、取值范围、sizeof操作符、变量和常量的概念,算术运算符、复合赋值符、printf和scanf函数及其占位符的使用。
摘要由CSDN通过智能技术生成

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 就是在占位符的百分号后⾯,加⼊了赋值忽略符 * ,表⽰这个占位符没有对应的 变量,解读后不必返回

  • 23
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值