一些课上小疑问
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了一些课上小疑问相关的知识,希望对你有一定的参考价值。
1.一个jave类文件中真的只能有一个共有类吗?
public class Test {
public static void main(String[] args) {
}
public class InterClass{
}
}
答: 一个jave源文件只能有一个共有类,但共有类中再定义共有类是允许的,如上面的程序在Eclipse中没有错误。
2.main方法
动手实验:把main()方法的返回值由void改为int,程序能编译通过吗?能运行吗?
public class Hello {
public static int main(String[] args) {
// TODO Auto-generated method stub
System.out.println("Hello");
}
}
不能通过,会出现错误,也不能运行。
3.什么是静态方法?
静态方法就是使用 static 关键字标识的方法,是使用公共内存空间的,就是说所有对象都可以直接引用,不需要创建对象再使用该方法。
4.思索,为什么jave规定作为程序入口点的main()方法静态的?
为什么要这么定义,和JVM的运行有关系。
当一个类中有main()方法,执行命令“java 类名”则会启动虚拟机执行该类中的main方法。
由于JVM在运行这个Java应用程序的时候,首先会调用main方法,调用时不实例化这个类的对象,而是通过类名直接调用。因此需要是限制为public static。
5.变量的作用域
课后练习: Java变量遵循“同名变量的屏蔽原则”,请课后阅读相关资料弄清楚相关知识,然后自己编写一些测试代码,就象本示例一样,有意识地在不同地方定义一些同名变量,看看输出的到底是哪个值。
输出结果:2
原因:因为在java中,局部定义的变量能够覆盖全局范围内的变量。在局部使用某个变量的时候JVM会优先找和当前使用位置"近"的变量的的定义!如果在局部定义了和全局变量一样的名字,我们使用的过程中,调用全局变量的话,会使用this关键字辅助。
6.java中的类型转换
动手动脑:查查java中每个数据类型所占位数,和表示数值的范围,你能得出什么结论?
byte:8位,最大存储数据量是255,存放的数据范围是-128~127之间。
short:16位,最大数据存储量是65536,数据范围是-32768~32767之间。
int:32位,最大数据存储容量是2的32次方减1,数据范围是负的2的31次方到正的2的31次方减1。
long:64位,最大数据存储容量是2的64次方减1,数据范围为负的2的63次方到正的2的63次方减1。
float:32位,数据范围在3.4e-45~1.4e38,直接赋值时必须在数字后加上f或F。
double:64位,数据范围在4.9e-324~1.8e308,赋值时可以加d或D也可以不加。
boolean:只有true和false两个取值。
char:16位,存储Unicode码,用单引号赋值。
从存储范围小的类型到存储范围大的类型也存在着精度损失,比如从int到float,double,还有从long到double。
7.运行TestDouble代码并分析结果。
public class TestDouble {
public static void main(String[] args) {
// TODO Auto-generated method stub
System.out.println("0.05+0.01="+(0.05+0.01));
System.out.println("1.0-0.42="+(1.0-0.42));
System.out.println("4.015*100="+(4.015*100));
System.out.println("123.3/100="+(123.3/100));
}
}
结论是,使用double类型的数值进行计算,其结果是不精确的。
原因是,这个涉及到二进制与十进制的转换问题。
N进制可以理解为:数值×基数的幂,例如我们熟悉的十进制数123.4=1×102+2×10+3×(10的0次幂)+4×(10的-1次幂);其它进制的也是同理,例如二进制数11.01=1×2+1×(2的0次幂)+0+1×(2的-2次幂)=十进制的3.25。
double类型的数值占用64bit,即64个二进制数,除去最高位表示正负符号的位,在最低位上一定会与实际数据存在误差(除非实际数据恰好是2的n次方)。
举个例子来说,比如要用4bit来表示小数3.26,从高到低位依次对应2的1,0,-1,-2次幂,根据最上面的分析,应当在二进制数11.01(对应十进制的3.25)和11.10(对应十进制的3.5)之间选择。
简单来说就是我们给出的数值,在大多数情况下需要比64bit更多的位数才能准确表示出来(甚至是需要无穷多位),而double类型的数值只有64bit,后面舍去的位数一定会带来误差,无法得到“数学上精确”的结果。
处理精度损失的方法,使用BigDecimal类
注意:在构造BigDecimal对象时应使用字符串而不是double数值,否则,仍有可能引发计算精度问题。(为什么会这样?)
在实际应用中,需要对更大或者更小的数进行运算和处理。float和double只能用来做科学计算或者是工程计算,在商业计算中要用java.math.BigDecimal。BigDecimal所创建的是对象,我们不能使用传统的+、-、*、/等算术运算符直接对其对象进行数学运算,而必须调用其相对应的方法。方法中的参数也必须是BigDecimal的对象。构造器是类的特殊方法,专门用来创建对象,特别是带有参数的对象。
7.动手动脑
以下代码的输出结果是什么?
int X=100;
int Y=200;
System.out.println("X+Y="+X+Y);
System.out.println(X+Y+"=X+Y");
为什么会有这样的输出结果?
输出结果:2
原因:语句一的+是连接符,用来连接X Y 两个变量,所以输出的时候是100与200的值。语句二的+是加法运算符,用来做X+Y运算,输出的是100+200之后的值。
以上是关于一些课上小疑问的主要内容,如果未能解决你的问题,请参考以下文章