java读取文件面试题_如何从Java中的类路径真正读取文本文件

在类路径上的目录中,从同一类加载器加载的类中,你应该能够使用以下任一种:

// From ClassLoader, all paths are "absolute" already - there's no context

// from which they could be relative. Therefore you don't need a leading slash.

InputStream in = this.getClass().getClassLoader()

.getResourceAsStream("SomeTextFile.txt");

// From Class, the path is relative to the package of the class unless

// you include a leading slash, so if you don't want to use the current

// package, include a slash like this:

InputStream in = this.getClass().getResourceAsStream("/SomeTextFile.txt");

如果这些都不起作用,则表明还有其他问题。

因此,例如,使用以下代码:

package dummy;

import java.io.*;

public class Test

{

public static void main(String[] args)

{

InputStream stream = Test.class.getResourceAsStream("/SomeTextFile.txt");

System.out.println(stream != null);

stream = Test.class.getClassLoader().getResourceAsStream("SomeTextFile.txt");

System.out.println(stream != null);

}

}

而这个目录结构:

code

dummy

Test.class

txt

SomeTextFile.txt

然后(使用Linux机器上的Unix路径分隔符):

java -classpath code:txt dummy.Test

结果:

true

true

Overload和Override的区别。Overloaded的方法是否可以改变返回值的型? Overload是重载的意思,Override是覆盖的意思,也就是重写。 重载Overload表示同一个可以有多个名称相同的方法,但这些方法的参数列表各不相同(即参数个数或型不同)。 重写Override表示子的方法可以与父的某个方法的名称和参数完全相同,通过子创建的实例对象调用这个方法时,将调用子的定义方法,这相当于把父定义的那个完全相同的方法给覆盖了,这也是面向对象编程的多态性的一种表现。子覆盖父的方法时,只能比父抛出更少的异常,或者是抛出父抛出的异常的子异常,因为子可以解决父的一些问题,不能比父有更多的问题。子方法的访问权限只能比父的更大,不能更小。如果父的方法是private型,那么,子则不存在覆盖的限制,相当于子增加了一个全新的方法。 至于Overloaded的方法是否可以改变返回值的型这个问题,要看你倒底想问什么呢?这个题目很模糊。如果几个Overloaded的方法的参数列表不一样,它们的返回者型当然也可以不一样。但我估计你想问的问题是:如果两个方法的参数列表完全一样,是否可以让它们的返回值不同来实现重载Overload。这是不行的,我们可以用反证法来说明这个问题,因为我们有时候调用一个方法时也可以不定义返回结果变量,即不要关心其返回结果,例如,我们调用map.remove(key)方法时,虽然remove方法有返回值,但是我们通常都不会定义接收返回结果的变量,这时候假设该有两个名称和参数列表完全相同的方法,仅仅是返回型不同,java就无法确定编程者倒底是想调用哪个方法了,因为它无法通过返回结果型来判断。 override可以翻译为覆盖,从字面就可以知道,它是覆盖了一个方法并且对其重写,以求达到不同的作用。对我们来说最熟悉的覆盖就是对接口方法的实现,在接口一般只是对方法进行了声明,而我们在实现时,就需要实现接口声明的所有方法。除了这个典型的用法以外,我们在继承也可能会在子覆盖父的方法。在覆盖要注意以下的几点: 1、覆盖的方法的标志必须要和被覆盖的方法的标志完全匹配,才能达到覆盖的效果; 2、覆盖的方法的返回值必须和被覆盖的方法的返回一致; 3、覆盖的方法所抛出的异常必须和被覆盖方法的所抛出的异常一致,或者是其子; 4、被覆盖的方法不能为private,否则在其子只是新定义了一个方法,并没有对其进行覆盖。 overload对我们来说可能比较熟悉,可以翻译为重载,它是指我们可以定义一些名称相同的方法,通过定义不同的输入参数来区分这些方法,然后再调用时,VM就会根据不同的参数样式,来选择合适的方法执行。在使用重载要注意以下的几点: 1、在使用重载时只能通过不同的参数样式。例如,不同的参数型,不同的参数个数,不同的参数顺序(当然,同一方法内的几个参数型必须不一样,例如可以是fun(int,float),但是不能为fun(int,int)); 2、不能通过访问权限、返回型、抛出的异常进行重载; 3、方法的异常型和数目不会对重载造成影响; 4、对于继承来说,如果某一方法在父是访问权限是priavte,那么就不能在子对其进行重载,如果定义的话,也只是定义了一个新方法,而不会达到重载的效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值