主要讲了变量 常量和运算符(部分)
变量是指在程序运行中数值会被改变,格式为: <存储类型><数据类型> 变量名;
存储类型分为:auto volatile register static extern const
数据类型为: int 、short、 lang 、 lang lang 、 unsigned short 、unsinged long、unsignedlong long、 char 、 unsigned char、 float、double
变量名的命名规格:不能是数字,不能是关键字,命名时应该容易理解意思,严格区分大小写
大驼峰 :每个单词的首字符大写 小驼峰: 除了第一个单词得其他单词得首字母都大写
凹凸命名法:多个单词之间使用_分割
32个关键字为: 12个数据类型:signed/ unsigned /char/ short/ int /long /enum/ union/ float/ double/ void 6个存储类型: auto / volatile / register / static /extern /const
1个类型重定义: sizeof 12个控制关键字: if / for/ else / while / switch / do / case /default /return/ goto/ break / continue
常量:就是不能改变得数据
其中有整形常量、字符常量、字符产常量、浮点型常量、标识常量(宏定义){主要是#define 名字 值}
源码 、补码、反码
根据chatgpt的说是 没有所谓的“源码”、“反码”和“补码”的概念。这些概念主要用于整数的表示。
整数表示:
源码是: 正数:直接将十进制转换成二进制 负数: 符号位为1,其余位为该数的绝对值的二进制形式 列子:+5 0000 0101 -5 1000 0101
反码:正数:反码和源码一样 负数:符号位一样,其余为取反
例子: +5 0000 0101 -5 1111 1010
补码: 正数:补码和源码一样 负数:再反码的基础上加1
例子: +5 0000 0101 -5 1111 1011
浮点数:浮点数没有源码、反码和补码的表示方法,而是使用符号位、指数位和尾数位来表示。
单精度浮点数(32位 float
)
- 符号位(S):1位,0表示正数,1表示负数。
- 指数位(E):8位,表示指数部分,使用偏移量为127的移码。
- 尾数位(M):23位,表示有效数字的小数部分,隐含的整数部分为1。
双精度浮点数(64位 double
)
- 符号位(S):1位,0表示正数,1表示负数。
- 指数位(E):11位,表示指数部分,使用偏移量为1023的移码。
- 尾数位(M):52位,表示有效数字的小数部分,隐含的整数部分为1
3.75 二进制位: 11.11 标准化:1.111 * 2^1
确定符号位: 符号位s:1(负数) 确定指数位: 1,加上偏移量127 得128 二进制位10000000
确定尾数位: 111后面补0到23位
1 10000000 1110000000000000000000000
讲了几个运算符,不想敲字了
自增(++
)和自减(--
)得详细的记录下,大学的时候就是有点不理解,
自增运算符(“++”)有前置自增和后置自增
前置自增/自减: 先将变量的值加一/减一,然后再使用增加/减少后的变量
后置自增/自减: 先使用变量的当前值,然后再将变量的值加一/减一
例子:代码写的不好,凑合着看