1.java中不能为形参制定默认值

解决办法是

在方法中给参数一些初始值,或者写成类,用不同的构造函数

例如:

public void yourMethod(Stringa, String b) { 
String aa= “default”; 
String bb= “dfadfa”;
If( a==null) {
    a  = aa;
}
…
}

 

或者写成多个重载的不同参数个数和类型,互相调用来满足默认形参 

f(int i){
      f(i,100); 
} 
 
f(int i,int j){ 
…
}

2. Java中不存在const,取而代之的是final.

const 形参用final形参代替


(1)final在java中定义常量,可作用于基本类型或者类类型,若是作用于类类型,则此类类型不能作为父类被继承,也就是说它的下面不能有子类,这样的类叫做原子类。 
C++中的const定义常量.
(2)Java中的final如果是对于基本类型,那和C++const是一样的 ,但是如果是对对象而言,不同了.
(3)final表示这个句柄是不可改变的 
final Object obj=(Object)new String("a"); 
obj=(Object)new String("hello");是非法的 
但是依然可以调用obj的方法。如((String)obj).length()是合法的,而C++如果一个对象被定义成const,就不能调用对象的方法。除非这个方法被定义成const.

package test;

/*final表示这个句柄是不可改变的 
final Object obj=(Object)new String("a"); 
obj=(Object)new String("hello");是非法的 
但是依然可以调用obj的方法。如((String)obj).length()是合法的 */

public class Test {
 public static void main(String[] args) {


 final Object obj=(Object)new String("a");
 //obj=(Object)new String("hello");//不能对终态局部变量obj赋值
 System.out.println(((String)obj).length());//但是依然可以调用obj的方法

 }}

final使用三种情况:数据,方法和类

(1).数据

1.空白final

是指被声明为final但却未给赋初值的字段.,但是必须在每个构造函数中对final字段赋值.

2.final参数

说明你无法在方法中更改参数引用所指向的对象.

class dog
{
Public void eat(){}
}
Public class animal
{
Void do(final dog dg)
{
Dg=new dog(); //报错
}
}

(2)final方法

防治任何继承类修改它的含义,保持不会被覆盖 .

类中所用的private方法都隐式的指定未final的,由于无法取用private方法,所以也就无法覆盖它,所以对private方法添加final无任何意义.

(3)final类

表明你不打算继承此类,相当于c#中的sealed.

sealed 修饰符表示密封

用于类时,表示该类不能再被继承,不能和 abstract 同时使用,因为这两个修饰符在含义上互相排斥

用于方法和属性时,表示该方法或属性不能再被继承,必须和 override 关键字一起使用,因为使用sealed 修饰符的方法或属性肯定是基类中相应的虚成员

通常用于实现第三方类库时不想被客户端继承,或用于没有必要再继承的类以防止滥用继承造成层次结构体系混乱

恰当的利用sealed 修饰符也可以提高一定的运行效率,因为不用考虑继承类会重写该成员

 

3.引用传递

如果我有两个int型的变量a和b,我想写一个方法来交换它们的值,应该怎么办?没有什么好办法,目前只有把你的整数基本类型int用外覆类Integer来代替,或者用数组形式组装起来,再使用就可以实现传“引用”了。

 

关于引用参数的结论:

基本类型和基本类型变量被当作参数传递给方法时,是值传递。在方法实体中,无法给原变量重新赋值,也无法改变它的值。

对象和引用型变量被当作参数传递给方法时,在方法实体中,无法给原变量重新赋值(即改变不了实参的值),但是可以改变它所指向对象的属性。

 

即实质上java不存在参数引用。

 

4.java不支持操作符重载,用重载方法代替

 

5 java中无namespace,  Java用包代替了命名空间

 

6 java泛型应该注意的几个地方:

不能用类型参数替换基本类型。因此,没有Pair<double>,只有Pair<Double>。其原因是类型擦除。删除之后,Pair类具有Object类型的域,而Object不能存储double值。解决办法是使用包装类,或者可以使用独立的类和方法来处理。

 

java的泛型,其实只是在编译时有效,保障编译期间的类型安全.在运行期,所有的泛型类型都会变成Object,这就是所谓的类型擦除