C++语言转java语言时遇到的问题

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值