每天一道面试题(3)----快问快答(2)

1.当一个对象被当作参数传递到另一个方法后,此方法可改变这个对象的属性,并可返回变化后的结果,那么这里到底是值传递还是引用传递?

是值传递。Java语言的方法调用只支持参数的值传递。当一个对象实例作为一个参数被传递到方法中时,参数的值就是对该对象的引用。对象的属性可以在被调用过程中被改变,但对对象引用的改变是不会影响到调用者的。在Java中没有传引用实在是非常的不方便,这一点在Java8中仍然没有得到改进,正是因为如此,在Java编写的代码才会出现大量的Wrapper类(将需要通过方法调用修改的引用置于一个Wrapper类中,再将Wrapper对象传入方法)。

2.重载(overload)和重写(override)的区别?重载的方法能否根据返回值类型进行区分?

方法的重载和重写都是实现多态的方式,区别在于前者实现的是编译时的多态性,而后者实现的是运行时的多态性。重载发生于一个类中,同名的方法如果有不同的参数列表(参数类型不同、参数个数不同或者二者都不同)则视为重载;重写发生在子类与父类之间,重写要求子类重写方法与父类被重写方法有相同的返回类型,比父类被重写方法更好访问,不能比父类被重写方法声明更多的异常(里氏代换原则)。重载对返回类型没有特殊的要求。

方法重载的规则:
  1. 方法名一致,参数列表中参数的顺序,类型,个数不同。
  2. 重载与方法的返回值无关,存在于父类和子类,同类中。
  3. 可以抛出不同的异常,可以有不同修饰符。

 方法重写的规则:

  1. 参数列表必须完全与被重写方法的一致,返回类型必须完全与被重写方法的返回类型一致。
  2. 构造方法不能被重写,声明为final的方法不能被重写,声明为static的方法不能被重写,但是能够再次声明。
  3. 访问权限不能比父类中被重写的方法的访问权限更低。
  4. 重写的方法能够抛出任何非强制异常(UncheckedException,也叫非运行时异常),无论被重写的方法是否抛出异常。但是,重写的方法不能抛出新的强制性异常,或者比被重写方法声明的更广泛的强制性异常,反之则可以。

3.为什么函数不能根据返回类型来区分重载?(来自华为面试题)

该道题来自华为面试题。

因为调用时不能指定类型信息,编译器不知道你要调用哪个函数。

例如:

float max(int a, int b);
int max(int a, int b);

当调用max(1,2)时无法确定调用的是哪个,单从这一点上来说,仅返回值类型不同的重载是不应该允许的。

再比如对下面这两个方法来说,虽然它们有同样的名字和自变量,但其实是很容易区分的:

void f(){}
int f(){}

若编译器可根据上下文(语境)明确判断出含义,比如在int x=f()中,那么这样做完全没有问题。然而,我们也可能调用一个方法,同时忽略返回值;我们通常把这称为“为它的副作用去调用一个方法”,因为我们关心的不是返回值,而是方法调用的其他效果。所以假如我们像下面这样调用方法:f();Java怎样判断f()的具体调用方式呢?而且别人如何识别并理解代码呢?由于存在这一类的问题,所以不能。

函数的返回值只是作为函数运行之后的一个“状态”,他是保持方法的调用者与被调用者进行通信的关键。并不能作为某个方法的“标识”。

4.char型变量中能不能存储一个中文汉字,为什么?

char类型可以存储一个中文汉字,因为Java中使用的编码是Unicode(不选择任何特定的编码,直接使用字符在字符集中的编号,这是统一的唯一方法),一个char类型占2个字节(16比特),所以放一个中文是没有问题的。

补充:使用Unicode意味着字符在JVM内部和外部有不同的表现形式,在JVM内部都是Unicode,当这个字符被从JVM内部转移到外部时(例如存入文件系统中),需要进行编码转换。所以Java中有字节流和字符流,以及在字符流和字节流之间进行转换的转换流,如InputStreamReader和OutputStreamReader,这两个类是字节流和字符流之间的适配器,承担了编码转换的任务;对于C程序员来说,要完成这样的编码转换恐怕要依赖于union(联合体/共用体)共享内存的特征来实现了。

5.抽象类(abstract class)和接口(interface)有什么异同?

抽象类:

  1. 抽象类中可以定义构造器
  2. 可以有抽象方法和具体方法
  3. 接口中的成员都是public
  4. 抽象类中可以定义成员变量
  5. 有抽象方法的类必须被声明为抽象类,而抽象类未必要有抽象方法
  6. 抽象类中可以包含静态方法
  7. 一个类只能继承一个抽象类

接口:

  1. 接口中不能定义构造器
  2. 方法可以是抽象方法(JDK7及以前)、默认方法(JDK8)和静态方法(JDK8)
  3. 抽象类中的成员可以是private、默认、protected、public
  4. 接口中定义的成员变量实际上都是常量
  5. 一个类可以实现多个接口 

相同点:

  1. 不能够实例化
  2. 可以将抽象类和接口类型作为引用类型
  3. 一个类如果继承了某个抽象类或者实现了某个接口都需要对其中的抽象方法全部进行实现,否则该类仍然需要被声明为抽象类 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值