一java语言浮点两种形式
1,十进制,必须包含一个小数点.
2,科学计数法形式,例如5.21e2(5.21*10^2)或5.21E2.
二 java语言默认浮点类型是double类型,浮点类型值后紧跟f或F,当float类型.
三 java语言三个特殊浮点值:正无穷大,负无穷小和非数(负数开方,或0.0除0.0),用于表示溢出和出错.
1 正无穷大通过POSITIVE_INFINITY表示 例 double d = Double.POSITIVE_INFINITY;
2 负无穷小通过NEGATIVE_INFINITY表示
3 非数通过NaN表示.
所有的正无穷大数值都相等,负无穷小数值都相等,非数和任何数值(包括非数)都不相等.
遇到问题:
double result=(ft*b) + +(1*ft)+(i/c)-(db*s);
两个加号为什么要用空格隔开?感觉书上错了.
构造器继承问题
在java中,经常使用到继承,子类从父类中继承可继承的域和方法。而关于构造器的构造器却和一般的继承有很大不同。以下面为例。
package Thinking;
public class Father{
public int n;
public Father(int n){
this.n=n;
}
public Father(String msg){
System.out.println(msg);
}
}
class Son extends Father{
public Son(String msg){ //编译无法通过
System.out.println(msg);
}
}
上述代码中,Son是Father的子类,父类有两个构造函数,一个参数为int,一个参数为String,而Son的构造函数和父类第二个构造函数一样。然而Son却无法通过编译,这是因为子类的构造器重隐含着对父类无参构造器的调用,若父类没有无参构造器,那子类必须在构造器中显式调用父类的其中一个有参构造器,否则无法通过编译。
所以上述代码中,可以有两种解决办法。一是在父类添加一个无参构造器,二是在子类中添加一个对父类构造器的显示调用(super(param))。这样才可通过编译。
方法一:
package Thinking;
public class Father{
public int n;
public Father(){
System.out.println("Father");
}
public Father(int n){
this.n=n;
}
public Father(String msg){
System.out.println(msg);
}
}
class Son extends Father{
public Son(String msg){
System.out.println(msg);
}
}
方法二:
package Thinking;
public class Father{
public int n;
public Father(int n){
this.n=n;
}
public Father(String msg){
System.out.println(msg);
}
}
class Son extends Father{
public Son(String msg){
super(msg);
System.out.println(msg);
}
}
此外当父类没有无参构造器时,子类无法使用系统默认的构造器,必须创建自己的构造器,无论是否有参数。