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,这就是所谓的类型擦除。