今天敲代码了吗?   

课程作业02-2

1、一个Java类文件中真的只能有一个公有类吗
public class text {
public static void main(String[] args)
{
System.out.println(".01");
}
public class InnerClass{

}
}
一个Java源文件中最多只能有一个public类,当有一个public类时,源文件名必须与之一致,否则无法编译,如果源文件中没有一个public类,则文件名与类中没有一致性要求。

至于main()不是必须要放在public类中才能运行程序。

2、把main()方法的返回值由 void 改为 int ,程序能编译通过吗?能运行吗?
不能 必须返回int类型的结果

3、为什么java规定作为程序入口点的main() 方法静态的?

非静态成员函数在执行前必须先构造并实例化该函数所在的类。如果允许非静态的main,那么main函数所在的类必须先进行实例化,

那么就需要再写个函数去实例化main所在的类,再调用main,这个实例化代码需要去再实现。如果它也是非静态的,有需要写一个实例化,一直重复不能实现。
因此,JAVA语言就规定了main必须是静态的。

4、请看左边的示例代码,输出结果是什么?
public class text {
private static int value=1;
public static void main(String[] args)
{
int value=2;
System.out.println(value);
}
}
结果为2

public class text {
private static int value=1;
private String a="a";
public static void main(String[] args)
{
int value=2;
String a="b";
System.out.println(value);
System.out.println(a);
}
}
结果为 2 b
在代码中,第一个value是成员变量,也是全局变量,第二个value是局部变量,
局部变量可以覆盖全局变量,在局部使用某个变量的时候JVM会优先找和当前使用位置近的变量定义.

5、看着这个图,再查查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时有精度损失

6、为什么double类型的数值进行运算得不到“数学上精确”的结果?

N进制可以理解为:数值×基数的幂,例如我们熟悉的十进制数123.4=1×10²+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更多的位数才能准确表示出来(甚至是需要无穷多位),而dou
ble类型的数值只有64bit,后面舍去的位数一定会带来误差,无法得到“数学上精确”的结果。float 和double类型主要是为科学计算和工程计算而设计的,他们执行二进制浮点运算,这两种类型在计算机中的储存分为三部分:符号位、指数为、尾数部分。数据以二进制存储在计算机时,会出现无线循环系列,在数据转化中会出现错误。十进制不能准确的表示1/3,同样二进制不能精确的表示1/10。

 7、在构建BigDecimal对象时应使用字符串而不是double数值,否则,仍有可能引发计算精度问题。(为什么会这样呢?)

double+、-不能准确的代表BigDecimal(String) 16位有效数以上的数字在使用BigDecimal时,用*、/构造器创建
对象。BigDecimal所创建的对象不能使用传统的等算术运算符直接对其对象进行数学运算,必须调用相对应的方法。
方法中的参数必须是BigDecimal的对象。


8、以下代码输出什么?

以下代码的输出结果是什么?

int X=100;

int Y=200;

System.out.println("X+Y="+X+Y);

System.out.println(X+Y+"=X+Y");

输出结果:X+Y=100200 300=X+Y

为什么会有这样的输出?

在语句一中,“+”是连接量,直接连接两个字符;
在语句二中,“+”是运算符,进行数值类型的求和运算。

posted on 2017-10-06 17:06  今天学算法了吗?  阅读(128)  评论(0编辑  收藏  举报

导航