002==数据类型转换,运算符
1.自动转换:将 取值范围小的类型 自动提升为 取值范围大的类型 。
2.byte(1字节)、short(2)、char(2)‐‐>int(4)‐‐>long(8)‐‐>float(4)‐‐>double(8)
3.强制类型转换:将 取值范围大的类型 强制转换成 取值范围小的类型 。
4.数据类型 变量名 = (数据类型)被转数据值;
5.编码表(ASCII编码表) :就是将人类的文字和一个十进制数进行对应起来组成一张表格。
6.在char类型和int类型计算的过程中,char类型的字符先查询编码表,得到97,再和1求和,结果为98。char类型提升 为了int类型。char类型内存2个字节,int类型内存4个字节。
7.
public static void main(String[] args) {
//字符类型变量
char c = 'a';
int i = 1;
//字符类型和int类型计算
System.out.println(c+i);//输出结果是98
}
8.整数使用以上运算符,无论怎么计算,也不会得到小数。
9.变量在独立运算时, 前++ 和 后++ 没有区别 。
10.和其他变量放在一起, 前++ 和 后++ 就产生了不同。 变量 前++ :变量a自己加1,将加1后的结果赋值给b,也就是说a先计算。a和b的结果都是2。
11.变量 后++ :变量a先把自己的值1,赋值给变量b,此时变量b的值就是1,变量a自己再加1。a的结果是2,b 的结果是1。
12.赋值运算符:i+=5;//计算方式 i=i+5 变量i先加5,再赋值变量i .
13.三元运算符
public static void main(String[] args) {
int i = (1==2 ? 100 : 200);
System.out.println(i);//200
int j = (3<=4 ? 500 : 600);
System.out.println(j);//500
}
14.方法必须定义在一类中方法外,方法不能定义在另一个方法的里面.
15.s += 1 逻辑上看作是 s = s + 1 计算结果被提升为int类型,再向short类型赋值时发生错误,因为不能将取值范围 大的类型赋值到取值范围小的类型。但是, s=s+1进行两次运算 , += 是一个运算符,只运算一次,并带有强制转换的特点, 也就是说 s += 1 就是 s = (short)(s + 1) ,因此程序没有问题编译通过,运行结果是2.
16. b3 = 1 + 2 , 1 和 2 是常量,为固定不变的数据,在编译的时候(编译器javac),已经确定了 1+2 的结果并没 有超过byte类型的取值范围,可以赋值给变量 b3 ,因此 b3=1 + 2 是正确的。
反之, b4 = b2 + b3 , b2 和 b3 是变量,变量的值是可能变化的,在编译的时候,编译器javac不确定b2+b3的结果是什 么,因此会将结果以int类型进行处理,所以int类型不能赋值给byte类型,因此编译失败。
17.
上一篇: Python-基本数据类型和命名规则
推荐阅读
-
解决无法在unicode和非unicode字符串数据类型之间转换的方法详解
-
chapter1:python 基础(数据类型,运算符,常用内置函数,模型,strings等)
-
对text数据类型不支持代码页转换 从: 1252 到: 936
-
Python基础语法(赋值、数据运算、数据类型转换、字符串各种操作)
-
php学习之数据类型之间的转换代码
-
winform dateTime数据类型转换方法
-
js数值计算时使用parseInt进行数据类型转换(jquery)
-
c/c++编程排坑(1)-- 数据类型的“安静”转换
-
Pandas实现数据类型转换的一些小技巧汇总
-
Numpy数据类型转换astype,dtype的方法