发表时间:2022-03-25来源:网络
Java程序中要求参与运算的数据,必须要保证数据而理性的一致性,如果数据类型不一致,将发生类型的转换。
一个int类型的变量和一个byte类型的变量进行加法运算,结果会是什么数据类型?
int i = 1; byte b = 2;运算结果,变量的类型将是int类型,这就是出现了数据类型的自动类型转换现象。
自动类型转换:将取值范围小的类型自动提升为取值范围大的类型。public class Test01{ public static void main(String[] args) { int i = 1; byte b = 2; // byte c = b + 1; // 报错 // int类型和byte类型运算结果是int类型 int c = b + i; System.out.println(c); } }
byte类型占用1个字节,int类型占用4个字节,byte类型在和int类型运算时,会自动补充3个字节,因此计算后的结果还是int型。

同样道理,当一个int类型和double类型变量运算时,int类型会自动提升为double类型进行运算。
public class Test02{ public static void main(String[] args) { int i = 1; double d = 2.5; double c = d + i; System.out.println(c); } }
范围小的类型向范围大的类型提升,byte,short,char运算时直接提升为int。
byte,short,char-->int-->long-->float-->double将1.5赋值到int类型变量会发生什么?产生编译失败,肯定无法赋值。
int i = 1.5; // 错误double类型内存8个字节,int类型内存4个字节。1.5是double类型,取值范围大于int。
想要赋值成功,只有通过强制类型转换成取值范围小的类型。
比较而言,自动类型转换是java自动执行的,而强制转换需要我们自己手动执行。
转换格式:
数据类型 变量名 = (数据类型) 被转换的数据值将1.5赋值到int类型,代码修改为:
// double类型数据强制转成int类型,直接去掉小数点 int i= (int) 1.5;同样道理,当一个short类型与1相加,我们知道会类型提升,但是还想把结果赋值给short类型变量,就需要强制类型转换。
public class Test03{ public static void main(String[] args) { short s = 1; // 编译失败 // s = s + 1; s = (short) (s+1); System.out.println(s); } }浮点数转成整数,直接取消小数点,可能造成数据损失精度。
int强制转成short砍掉2个字节,可能造成数据丢失。
// 定义s为short范围内最大的数值 short s = 32767; // 运算后,强制转换,砍掉2个字节后会出现不确定的结果。 s = (short) (s + 10);在计算机的内部都是二进制的0,1数据,如何让计算机可以直接识别人类的文字呢?就产生出了编码表的概念。
编码表:就是将人类的文字和一个十进制数进行对应起来组成一张表格。字符数值048957A65Z90a97z122将所有的英文字母,数字,符号都和十进制进行了对应,因此产生了世界上第一张码表ASCII(American Standard Code for Information Interchange美国标准信息交换码)
小贴士:
在char类型和int类型计算的过程中,char类型的字符先查询编码表,得到97,再和1求和,结果为98.char类型提升为int类型。char类型内存2个字节,int类型内存4个字节。
Java中使用以上运算符,怎么计算都不会得到小数。
public static void main(String[] args){ int i = 1234; System.out.println(i/1000*1000)// 计算结果是1000 }++运算符,变量自己增长1,反之,--运算,变量自己减少1++在独立运算时,前++和后++没有区别
变量前++:例如++i;
变量后++,例如i++;
混合运算时,和其他变量一起,前++和后++就产生区别了。
变量前++:变量a自己加1,将加1后的结果赋值给b,也就是说先a先计算,a和b的结果都是2.
public static void main(String[] args){ int a = 1; int b = ++a; System.out.println(a);// 计算结果是2 System.out.println(b);//计算结果是2 }这里的int b = ++a;可以拆分成两句,a = a + 1;int b = a;所以这里的b就等于2.
变量后++:变量a先把自己的值1,赋值给b,此时的变量b的值就是1,变量a自己在加1,a的结果就是2,b的结果就是1.
public static void main(String[] args){ int a = 1; int b = a++; System.out.println(a); //计算结果是2 System.out.println(b); // 计算结果是1 }这里的int b = a++;可以拆分成两句代码:int b = a; a = a + 1;所以这里的b就是1,a就是2.
+符号在字符串中的操作+符号遇到字符串的时候,表示连接,拼接的含义。
"a"+"b" 的结果是"ab"
public static void main(String[] args){ System.out.println("a"+"b");// 输出ab }赋值运算符,就是将符号右边的值,赋给左边的变量。
public static void main(String[] args){ int i = 5; i += 5;// 计算方式 i = i + 5; System.out.println(i); //输出结果是10; }比较运算符,是两个数据之间进行比较的运算,运算结果都是布尔值true或者false。
public class Test04{ public static void main(String[] args) { System.out.println(1==1);//true System.out.println(14);//false System.out.println(3=4);//false System.out.println(3>=4);//false System.out.println(3!=4);//true } }
逻辑运算发,是用来连接两个布尔类型结果的运算符,运算结果都是布尔值true或者false
三元运算符格式
数据类型 变量名 = 布尔类型表达式?结果1:结果2
三元运算符计算方式:
布尔类型表达式结果为true时,三元运算符整体结果为结果1,赋值给变量。
布尔类型表达式结果为false时,三元运算符整体结果为结果2,赋值给变量。
布尔类型有时还会嵌套使用。
public class Test05{ public static void main(String[] args) { int i = (1>2)?500:600; System.out.println(i);//600 int j = (4>3)?100:200; System.out.println(j);//100 int age = 40; String person = (age>60)?"老年人":(age > 30)?"壮年人":(age>18)?"青年人":(age>0)?"少年人":"年龄不正确"; System.out.println(person); } }
我们在学习运算符的时候,都为每个运算符单独创建一个新的类和main方法,我们会发现这些写代码非常的繁琐,而且重复的代码过多,能否避免这些重复的代码呢,就需要使用方法来实现。
方法:就是将一个功能抽取出来,把代码单独定义在一个大括号里面,形成一个单独的功能。当我们需要这个功能的时候,就可以去调用,这样即可实现了代码的复用性,也解决了代码冗余的现象。
定义格式:
修饰符 返回值类型 方法名 (参数列表){ 代码。。。。 return ; }格式的解释:
修饰符:目前固定写法 public static
返回值类型:目前固定写法void,其他返回值类型在后面会详细介绍。
方法名:为我们定义的方法起名,满足标识符的规范,用来调用方法。
参数列表:目前无参数,带有参数的方法在后面会详细介绍。
return :方法结束,因为返回值类型是void,方法大括号内的return可以不写。
举例:
public static void methodName(){ System.out.println("这是一个方法"); }方法在定义完成之后,方法不会自己运行,必须被调用方才能执行,我们可以在主方法main中调用我们自己定义好的方法,在主方法中,直接写要调用的名字就可以调用了。
public class Test06{ public static void main(String[] args) { method(); } public static void method(){ System.out.println("自己定义的放大,需要被main调用运行"); } }将三元运算符代码抽取到自定义的方法中,并调用。
public class Test07{ public static void main(String[] args) { method(); } public static void method(){ int i = (1>2)?500:600; System.out.println(i);//600 int j = (4>3)?100:200; System.out.println(j);//100 int age = 40; String person = (age>60)?"老年人":(age > 30)?"壮年人":(age>18)?"青年人":(age>0)?"少年人":"年龄不正确"; System.out.println(person); } }方法必须定义在类内。
方法不能定义在另一个方法内。
分析:s+=1逻辑上看作是 s = s + 1计算结果被提升为int类型,再向short类型赋值时发生错误,因为不能将取值范围大的类型赋值到取值范围小的类型。但是,s=s+1进行两次运算,+=是一个运算符,只运算一次,并带有强制转换的特点,也就是说s+=1就是s= (short)(s+1),因此,程序没有问题,编译通过,运行结果是2.
下面程序有问题吗?
public class Test08{ public static void main(String[] args) { byte b1 = 1; byte b2 = 2; byte b3 = 1 + 2; byte b4 = b1 + b2; System.out.println(b3); System.out.println(b4); } }分析:b3 = 1 + 2,1和2是常量,为固定不变的数据,在编译的时候(编译器javac),已经确定了1+2的结果并没有超过byte类型的取值范围,可以赋值给变量b3,因此b3=1+2是正确的。
反之,b4 = b1+b2,b1和b2是变量,变量的值是可能变化的,在编译的时候,编译器javac不确定b1+b2的结果是什么,因此会将结果以int类型进行处理,所以int类型不能赋值给byte类型,因此编译失败。
上一篇:Java中基本数据类型转换的方法
下一篇:java中的基本数据类型的转换
皓盘云建最新版下载v9.0 安卓版
53.38MB |商务办公
ris云客移动销售系统最新版下载v1.1.25 安卓手机版
42.71M |商务办公
粤语翻译帮app下载v1.1.1 安卓版
60.01MB |生活服务
人生笔记app官方版下载v1.19.4 安卓版
125.88MB |系统工具
萝卜笔记app下载v1.1.6 安卓版
46.29MB |生活服务
贯联商户端app下载v6.1.8 安卓版
12.54MB |商务办公
jotmo笔记app下载v2.30.0 安卓版
50.06MB |系统工具
鑫钜出行共享汽车app下载v1.5.2
44.7M |生活服务