java面试题

java面试题

ID:68925361

大小:152.00 KB

页数:52页

时间:2021-11-16

java面试题_第1页
java面试题_第2页
java面试题_第3页
java面试题_第4页
java面试题_第5页
java面试题_第6页
java面试题_第7页
java面试题_第8页
java面试题_第9页
java面试题_第10页
资源描述:

《java面试题》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、-.53道Java线程面试题下面是Java线程相关的热门面试题,你可以用它来好好准备面试。线程是操作系统能够进展运算调度的最小单位,它被包含在进程之中,是进程中的实际运作单位。程序员可以通过它进展多处理器编程,你可以使用多线程对运算密集型任务提速。比方,如果一个线程完成一个任务要100毫秒,那么用十个线程完成改任务只需10毫秒。Java在语言层面对多线程提供了卓越的支持,它也是一个很好的卖点。线程是进程的子集,一个进程可以有很多线程,每条线程并行执行不同的任务。不同的进程使用不同的存空间,而所有的线程共享一片一样的存空间。别把它和栈存搞混,每个线程都拥有单独的栈存用来存储本地数据。在

2、语言层面有两种方式。java.lang.Thread类的实例就是一个线程但是它需要调用java.lang.Runnable接口来执行,由于线程类本身就是调用的Runnable接口所以你可以继承java.lang.Thread类或者直接调用Runnable接口来重写run()方法实现线程。这个问题是上题的后续,大家都知道我们可以通过继承Thread类或者调用Runnable--.可修编-.-.接口来实现线程,问题是,那个方法更好呢?什么情况下使用它?这个问题很容易答复,如果你知道Java不支持类的多重继承,但允许你调用多个接口。所以如果你要继承其他类,当然是调用Runnable接口好了

3、。这个问题经常被问到,但还是能从此区分出面试者对Java线程模型的理解程度。start()方法被用来启动新创立的线程,而且start()部调用了run()方法,这和直接调用run()方法的效果不一样。当你调用run()方法的时候,只会是在原来的线程中调用,没有新的线程启动,start()方法才会启动新线程。Runnable和Callable都代表那些要在不同的线程中执行的任务。Runnable从JDK1.0开场就有了,Callable是在JDK1.5增加的。它们的主要区别是Callable的call()方法可以返回值和抛出异常,而Runnable的run()方法没有这些功能。Call

4、able可以返回装载有计算结果的Future对象。CyclicBarrier和CountDownLatch都可以用来让一组线程等待其它线程。与CyclicBarrier不同的是,CountdownLatch不能重新使用。Java存模型规定和指引Java程序在不同的存架构、CPU和操作系统间有确定性地行为。它在多线程的情况下尤其重要。Java存模型对一个线程所做的变动能被其它线程可见提供了保证,它们之间是先行发生关系。这个关系定义了一些规那么让程序员在并发编程时思路更清晰。比方,先行发生关系确保了:--.可修编-.-.·线程的代码能够按先后顺序执行,这被称为程序次序规那么。·对于同一个

5、锁,一个解锁操作一定要发生在时间上后发生的另一个锁定操作之前,也叫做管程锁定规那么。·前一个对volatile的写操作在后一个volatile的读操作之前,也叫volatile变量规那么。·一个线程的任何操作必需在这个线程的start()调用之后,也叫作线程启动规那么。·一个线程的所有操作都会在线程终止之前,线程终止规那么。·一个对象的终结操作必需在这个对象构造完成之后,也叫对象终结规那么。·可传递性我强烈建议大家阅读?Java并发编程实践?第十六章来加深对Java存模型的理解。volatile是一个特殊的修饰符,只有成员变量才能使用它。在Java并发程序缺少同步类的情况下,多线程对

6、成员变量的操作对其它线程是透明的。volatile变量可以保证下一个读取操作会在前一个写操作之后发生,就是上一题的volatile变量规那么。如果你的代码所在的进程中有多个线程在同时运行,而这些线程可能会同时运行这段代码。如果每次运行结果和单线程运行的结果是一样的,而且其他的变量的值也和预期的是一样的,就是线程平安的。一个线程平安的计数器类的同一个实例对象在被多个线程使用的情况下也不会出现计算失误。很显然你可以将集合类分成两组,线程平安和非线程平安的。Vector是用同步方法来实现线程平安的,而和它相似的ArrayList不是线程平安的。--.可修编-.-.竞态条件会导致程序在并发情

7、况下出现一些bugs。多线程对一些资源的竞争的时候就会产生竞态条件,如果首先要执行的程序竞争失败排到后面执行了,那么整个程序就会出现一些不确定的bugs。这种bugs很难发现而且会重复出现,因为线程间的随机竞争。Java提供了很丰富的API但没有为停顿线程提供API。JDK1.0本来有一些像stop(),suspend()和resume()的控制方法但是由于潜在的死锁威胁因此在后续的JDK版本中他们被弃用了,之后JavaAPI的设计者就没有提供一个兼容且线

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。