Java线程面试题

上传人:壹****1 文档编号:504288207 上传时间:2023-05-28 格式:DOCX 页数:9 大小:27.24KB
返回 下载 相关 举报
Java线程面试题_第1页
第1页 / 共9页
Java线程面试题_第2页
第2页 / 共9页
Java线程面试题_第3页
第3页 / 共9页
Java线程面试题_第4页
第4页 / 共9页
Java线程面试题_第5页
第5页 / 共9页
点击查看更多>>
资源描述

《Java线程面试题》由会员分享,可在线阅读,更多相关《Java线程面试题(9页珍藏版)》请在金锄头文库上搜索。

1、精选Java线程面试题Java是一门面向对象编程语言,不仅吸收了 C+语言的各种优 点,还摒弃了 C+里难以理解的多继承、指针等概念。下面是小编 搜集的Java线程题,欢迎大家阅读。1)什么是线程?线程是操作系统能够进行运算调度的最小单位,它被包含在进 程之中,是进程中的实际运作单位。程序员可以通过它进行多处理器 编程,你可以使用多线程对运算密集型任务提速。比如,如果一个线 程完成一个任务要100毫秒,那么用十个线程完成改任务只需10毫 秒。Java在语言层面对多线程提供了卓越的支持,它也是一个很好 的卖点。欲了解更多详细信息请点击这里。2)线程和进程有什么区别?线程是进程的子集,一个进程可以

2、有很多线程,每条线程并行 执行不同的任务。不同的进程使用不同的内存空间, 而所有的线程共 享一片相同的内存空间。别把它和栈内存搞混,每个线程都拥有单独 的栈内存用来存储本地数据。更多详细信息请点击这里。3)如何在Java中实现线程?在语言层面有两种方式。java。 lang。Thread类的实例就是 一个线程但是它需要调用java。lang。Runnable接口来执行,由于 线程类本身就是调用的 Runnable接口所以你可以继承java。lang。 Thread类或者直接调用Runnable接口来重写run ()方法实现线 程。更多详细信息请点击这里。4)用 Runnable 还是 Thre

3、ad ?这个问题是上题的后续,大家都知道我们可以通过继承Thread 类或者调用Runnable接口来实现线程,问题是,那个方法更好呢? 什么情况下使用它?这个问题很容易回答,如果你知道Java不支持类的多重继承,但允许你调用多个接口。所以如果你要继承其他类, 当然是调用Runnable接口好了。更多详细信息请点击这里。5) Thread类中的start () 和run () 方法有什么区别?这个问题经常被问到,但还是能从此区分出面试者对 Java线程 模型的理解程度。start ()方法被用来启动新创建的线程,而且start ()内部调用了 run ()方法,这和直接调用run ()方法的效

4、果不 一样。当你调用run ()方法的时候,只会是在原来的线程中调用, 没有新的线程启动,start ()方法才会启动新线程。更多讨论请点 击这里6) Java 中 Runnable 和 Callable 有什么不同?Runnable和Callable都代表那些要在不同的线程中执行的任 务。Runnable 从 JDK1。0 开始就有了,Callable 是在 JDK1。5 增加的。它们的主要区别是 Callable的call ()方法可以返回值和抛出异常,而Runnable的run ()方法没有这些功能。Callable可以 返回装载有计算结果的Future对象。我的博客有更详细的说明。7)

5、 Java 中 CyclicBarrier 和 CountDownLatch有什么不同?CyclicBarrier 和CountDownLatch都可以用来让一组线程等待其它线程。与 CyclicBarrier 不同的是,CountdownLatch 不 能重新使用。点此查看更多信息和示例代码。8) Java 中 CyclicBarrier 和 CountDownLatch 有什么不同?CyclicBarrier 和CountDownLatch都可以用来让一组线程等待其它线程。与 CyclicBarrier 不同的是,CountdownLatch 不 能重新使用。9) Java内存模型是什么?

6、Java内存模型规定和指引Java程序在不同的内存架构、CPU 和操作系统间有确定性地行为。它在多线程的情况下尤其重要。Java 内存模型对一个线程所做的变动能被其它线程可见提供了保证,它 们之间是先行发生了关系。这个关系定义了一些规则让程序员在并发 编程时思路更清晰。比如,先行发生了关系确保了:线程内的代码能够按先后顺序执行,这被称为程序次序规则。对于同一个锁,一个解锁操作一定要发生在时间上后发生的另 一个锁定操作之前,也叫做管程锁定规则。前一个对volatile的写操作在后一个volatile的读操作之前, 也叫volatile变量规则。一个线程内的任何操作必需在这个线程的start ()

7、调用之后,也叫作线程启动规则。一个线程的所有操作都会在线程终止之前,线程终止规则。一个对象的终结操作必需在这个对象构造完成之后,也叫对象 终结规则。可传递性10) Java中的volatile 变量是什么?volatile是一个特殊的修饰符,只有成员变量才能使用它。在 Java并发程序缺少同步类的情况下,多线程对成员变量的操作对其 它线程是透明的。volatile变量可以保证下一个读取操作会在前一个 写操作之后发生,就是上一题的 volatile变量规则。11) 什么是线程安全? Vector是一个线程安全类吗?如果你的代码所在的进程中有多个线程在同时运行,而这些线 程可能会同时运行这段代码。

8、如果每次运行结果和单线程运行的结果 是一样的,而且其他的变量的值也和预期的是一样的,就是线程安全的。一个线程安全的计数器类的同一个实例对象在被多个线程使用 的情况下也不会出现计算失误。很显然你可以将集合类分成两组,线程安全和非线程安全的。Vector是用同步方法来实现线程安全的, 而和它相似的ArrayList不是线程安全的。12) ) Java中什么是竞态条件?举个例子说明。竞态条件会导致程序在并发情况下出现一些bugs。多线程对一些资源的竞争的时候就会产生竞态条件,如果首先要执行的程序竞争失败排到后面执行了,那么整个程序就会出现一些不确定的bugs。这种bugs很难发现而且会重复出现,因为

9、线程间的随机竞争。13) Java中如何停止一个线程?Java提供了很丰富的API但没有为停止线程提供 API o JDK 1。 0本来有一些像stop () , suspend () 和resume ()的控制方 法但是由于潜在的死锁威胁因此在后续的JDK版本中他们被弃用了,之后Java API的设计者就没有提供一个兼容且线程安全的方法来停 止一个线程。当run ()或者call ()方法执行完的时候线程会自 动结束,如果要手动结束一个线程,你可以用volatile布尔变量来退出run ()方法的循环或者是取消任务来中断线程。14) 一个线程运行时发生异常会怎样?这是我在一次面试中遇到的一个

10、很刁钻的Java面试题,简单的说,如果异常没有被捕获该线程将会停止执行。Thread。 UncaughtExceptionHandler是用于处理未捕获异常造成线程突然中 断情况的一个内嵌接口。当一个未捕获异常将造成线程中断的时 候 JVM 会使用 Thread。getUncaughtExceptionHandler ()来查 询线程的UncaughtExceptionHandler并将线程和异常作为参数传递给handler的uncaughtException ()方法 进行处理。15) 如何在两个线程间共享数据?你可以通过共享对象来实现这个目的,或者是使用像阻塞队列 这样并发的数据结构。(涉

11、及到在两个线程间共享对象)用 wait和notify方法实现 了生产者消费者模型。16) Java 中 notify 和 notifyAll 有什么区别?这又是一个刁钻的问题,因为多线程可以等待单监控锁,javaAPI的设计人员提供了一些方法当等待条件改变的时候通知它们,但是这些方法没有完全实现。notify ()方法不能唤醒某个具体的线程, 所以只有一个线程在等待的时候它才有用武之地。而 notifyAll () 唤醒所有线程并允许他们争夺锁确保了至少有一个线程能继续运行。17) 为什么wait, notify 和notifyAll这些方法不在thread 类里面?这是个设计相关的问题,它考

12、察的是面试者对现有系统和一些 普遍存在但看起来不合理的事物的看法。回答这些问题的时候,你要说明为什么把这些方法放在Object类里是有意义的,还有不把它放在Thread类里的原因。一个很明显的原因是 JAVA提供的锁是对象 级的而不是线程级的,每个对象都有锁,通过线程获得。如果线程需要等待某些锁那么调用对象中的wait ()方法就有意义了。如果wait ()方法定义在Thread类中,线程正在等待的是哪个锁就不明显了。简单的说,由于 wait , notify和notifyAll都是锁级别的操 作,所以把他们定义在 Object类中因为锁属于对象。18) 什么是ThreadLocal变量?Th

13、readLocal是Java里一种特殊的变量。每个线程都有一个 ThreadLocal就是每个线程都拥有了自己独立的一个变量,竞争条件被 彻底消除了。它是为创建代价高昂的对象获取线程安全的好方法,比如你可以用ThreadLocal 让SimpleDateFormat变成线程安全的,因为那个类创建代价高昂且每次调用都需要创建不同的实例所 以不值得在局部范围使用它,如果为每个线程提供一个自己独有的变 量拷贝,将大大提高效率。首先,通过复用减少了代价高昂的对象的创建个数。其次,你在没有使用高代价的同步或者不变性的情况下 获得了线程安全。线程局部变量的另一个不错的例子是 ThreadLocalRand

14、om类,它在多线程环境中减少了创建代价高昂的Random对象的个数。19)什么是 FutureTask ?在Java并发程序中FutureT ask表示一个可以取消的异步运算。它有启动和取消运算、查询运算是否完成和取回运算结果等方法。只 有当运算完 成的时候结果才能取回,如果运算尚未完成 get方法将 会阻塞。一个FutureTask对象可以又t调用了 Callable和Runnable 的对象进行包 装,由于FutureTask也是调用了 Runnable接口所以 它可以提交给Executor来执行。20) Java 中 interrupted 和 isInterruptedd 方法的区别?

15、interrupted () 和isInterrupted ()的主要区别是前者会将中断状态清除而后者不会。Java多线程的中断机制是用内部标识来 实现的,调用Thread。interrupt ()来中断一个线程就会设置中断 标识为true。当中断线程调用静态方法 Thread。interrupted ()来 检查中断状态时,中断状态会被清零。而非静态方法isInterrupted()用来查询其它线程的中断状态且不会改变中断状态标识。简单的说就是任何抛 出InterruptedException异常的方法都会将中断状态清零。无论如何,一个线程的中断状态有有可能被其它线程调用中 断来改变。21)

16、 )为什么wait和notify方法要在同步块中调用?主要是因为Java API强制要求这样做,如果你不这么做,你的 代码会抛出 川egalMonitorStateException 异常。还有一个原因是 为了避免wait和notify之间产生竞态条件。22) )为什么你应该在循环中检查等待条件?处于等待状态的线程可能会收到错误警报和伪唤醒,如果不在 循环中检查等待条件,程序就会在没有满足结束条件的情况下退出。 因此,当一个等待线程醒来 时,不能认为它原来的等待状态仍然是 有效的,在notify ()方法调用之后和等待线程醒来之前这段时间它 可能会改变。23) Java中的同步集合与并发集合有什么区别?同步集合与并发集合都为多线程和并发

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 商业/管理/HR > 营销创新

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号