C学习记录2——数据类型
一、数据类型及其作用
1.数据类型
PS:关于精度
2.作用
编译器预算对象(变量)分配的内存大小
二、常量与变量
1.定义常量
(1)const 类型 名 = 值;
(c中不安全)
(2)宏定义常量
#define 名 值
2.定义变量
类型 变量名 = 值/表达式
PS:
声明变量
extern int a
不建立存储空间,不能赋值。
定义是声明的特例
全局变量:{ }外定义
局部变量:{ }内定义
变量名冲突时,局部优先
3.标识符命名规则
· 只包含字母、数字、下划线,不能以数字开头
· 不能包含空格,可用下划线分隔
· 不用关键字
· 应简短而有描述性
多个单词时:
(1)首字母大写(双驼峰命名)eg:RoleLv
(2)下划线分隔 eg:role_lv
整形
1.整形定义与输出
int a=值;
定义长整型
long a = 10l
加L表示长整型(L一般不写)
2.整形输入
scanf("%d",&a);
&运算符,表示取地址,以空格/回车结束
scanf("%d%d",&a,&b);
输出时空格/回车输入2个值printf("%d %d",a,b);
输入用占位符,可用修饰符 # 控制前导显示
%#o:在八进制前加0
%#X:在十六进制前加0X
三、字符型
char ' '
存一个字符(本质是一个字节大小的整形,可写入整数)
定义与输出
char ch = 'a';
printf("%c\n",ch);
PS:用%d可打印字符对应十进制数(ASCII码)
48——0、65——A、97——a(大小写字母,小写比大写大32)
四、转义字符
字符 | 描述 |
---|---|
\a | 警报 |
\b | 退格,将当前位置移到前一列 |
\f | 换页,将当前位置移到下页开头 |
\n | 换行 |
\r | 回车,本行开头 |
\t | 水平制表(跳8格) |
\v | 垂直制表 |
\t实际上会跳num=|n-8| % 8 格
五、浮点型
float a = 3.14f;
不以f结尾为double类型
printf("%f\n",a);
%f默认保留6位小数(四舍五入)%.xf x位小数
1.浮点型数据存储格式
符号位、指数位、小数位
用printf("%p\n",&a);
时无法读出地址
2.科学计数法
a=3.2e3f=3.2*103(f可不加)(e可写E)
六、计算机内存数值存储方式
1.原码(原始二进制码)
·最高位为符号位,0正,1负
·其它数值部分为本身的绝对值
·不便于加减运算
2.反码
·对正数,反码与原码相同
·对负数,符号位不变,其它部分取反(1——0,0——1)
·运算也不方便,通常为求补码的过渡
3.补码
·正数,原、反、补码相同
·负数,补码为其反码加1
·补码符号位不动,其他位求反,最后整个数加1,得到原码(负数)
数据在计算机中主要以补码形式储存
原因:
·统一了零的编码
·将符号位和其他位统一处理
·将减法运算转化为加法
·补码表示的数相加时,符号位有进位则舍弃
4.存储大小
有符号 8 bit位(1字节)存储数据
最大为 27-1=127 (0111 1111)最小为-27=-128(1000 0000)
PS:1000 0000是-0对应的值,作为-128的原码和补码
同理 int取值范围-231 ~ 231-1
unsigned char 0 ~ 255
5.数值溢出
超过一个数据类型能存放的最大范围时,数值溢出,最高位丢失
char a = 127;
a=a+1;
printf("%d\n",a);
输出:-128
七、类型限定符
1.extern
声明一个变量,不建立存储空间(定义时建立)
extern int a;
2.register
定义寄存器变量,提高效率
建议型指令,若CPU有空闲寄存器则生效,若无,则无效
3.const
定义常量
4.volatile
防止编译器优化代码
e.g.:定义 int num,之后若num未使用会被优化,加volatile防止。
八、字符串格式化输入输出
1.字符串常量
- 内存中一段连续的char空间,以‘\0’结尾
- 是由双引号括起来的字符序列
- 占位符%s:输出一个字符串,遇‘\0’停止,若无\0,则向后至找到为止
2.printf、putchar
printf 输出字符串
putchar 输出一个char(可为变量、字符、转义字符,数字ASCII码范围内)
PS:printf的附加格式
附加 | 含义 |
---|---|
l(小写L) | 附加在d,u,x,o前,表长整型 |
- | 左对齐 |
m(一个整数) | 数据最小宽度 |
0 | 将输出前补上0直到占满指定列宽(不可搭配-) |
m.n(整数) | m:域宽,对应的输出项在输出设备上所占字符数 n:精度,说明浮点型小数位,不设定n,默认6位 |
3.getchar()
从标准输入设备读取一个char(多个则取第一个)
getchar()可用于暂时停留界面