知识屋:更实用的电脑技术知识网站
所在位置:首页 > 教育

Java入门第二课(数据类型转换,运算符,方法定义)

发表时间: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);

ASCII编码表

public static void main(String[] args){ // 字符类型变量 char c = 'a'; int i = 1; // 字符型和int型计算 System.out.println(c+i);// 输出结果是98 }

在计算机的内部都是二进制的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比较符号左边的数据是否大于右边的数据,如果大于结果是true=大于等于符号!=不等于符号

比较运算符,是两个数据之间进行比较的运算,运算结果都是布尔值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时结果是true
一边是false时,结果是false
短路特点:符号左边是false时,右边不再运算||两边都是false时结果是false
一边是true时,结果是true
短路特点:符号左边是true时,右边不再运算!!true结果是false
!false结果是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); } }


注意事项

方法必须定义在类内。

方法不能定义在另一个方法内。

扩展知识点

+=符号的扩展

public static void main( String [] args){ short s = 1; s += 1; System.out.println(s); }

分析: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类型,因此编译失败。

收藏
  • 人气文章
  • 最新文章
  • 下载排行榜
  • 热门排行榜