目录
变量的数据在计算机中的存储原理
变量里的数据在计算机中的存储原理:采用二进制:使用0、1,按照逢二进一的规则表示数据存储
计算机底层表示数据的最小单元:字节(1B=8b)
字符、图片和声音的存储
字符:按照ASCII编码表进行编码后存储
图片:由像素点组成(每个像素点数据:0-255*255*255表示其颜色)
声音:声音的模拟信号——>(采样、量化、编码)声音的数字信号
数据类型
基本数据类型(引用数据类型后面再讲)
整型
如果希望整型的字面量默认是long,需要在后面加L或者l(尽量不用小写l,很像1)
如果随便写小数字面量,默认是double,如果希望是float,在最后加上F或者f
字符型
只能存储一个字符,多了则报错:
自动类型转换
为什么要进行类型转换:
存在不同类型的变量赋值给其他类型的变量的需求
什么是自动类型转换:
类型范围小的变量可以直接赋值给类型范围大的变量
表达式的自动类型转换
表达式:几个变量/数据一起参与运算的形式
注意事项:
- 表达式的最终结果类型由表达式中的最高类型决定
- 表达式中,byte、short、char都是直接转换为int参与运算
强制类型转换
需求原因:类型范围大的变量或者数据,直接赋值给类型范围小的变量会报错
强制类型转换:
强行将类型范围大的数据赋值给类型范围小的变量
数据类型 变量2 = (数据类型)变量1
a(int类型)强转为byte类型
强行类型转换执行原理:在大范围内截取需要的小范围的数据
例如int类型数据1500强转byte类型:
1500(int)——>-36(byte)
注意事项:
- 强制类型转换可能导致数据溢出
- 浮点型强转为整型,丢掉小数部分,保留整数部分返回
算术运算符、+符号作连接符
由于两个整数相除不论怎么样结果都一定是整数(java中),如果需要两个整数相除得到小数的话,可以:
这样得到的就是小数:
“+”符号可以作连接符
- 字符串运算中用作连接符,结果还是字符串
自增、自减运算符
自增:++
自减:--
注意:
- 自增自减运算符不能操作字面量,只能操作变量
- 放在变量的前面:先加减再拿变量值运算。反之,放在后面就是先运算再加减
赋值运算符
基本赋值运算符
就是“=”,从左往右
扩展赋值运算符
注意:
扩展的赋值隐含了强制类型转换
关系运算符
判断数据是否满足条件,最终返回一个判断结果,这个结果是布尔类型的值:true或者false
逻辑运算符
把多个条件放在一起运算,最终返回布尔类型的值:true或者false
注意:
- 在java中,&和| 无论左边是false还是true,右边都会进行判断执行
- 由于&&和||运算效率更高,在开发中用的更多
三元运算符和运算符优先级
三元运算符
格式:条件表达式?值1:值2;
执行流程:首先计算关系表达式的值,如果为true发挥值1,否则返回值2
运算符优先级
表达式中,运算符执行存在优先级
特殊说明:
新手学习记录,如有错误欢迎各位大佬指正,笔记来源是b站黑马程序员视频