`

java多线程面试题(转)

 
阅读更多

0.Java 中多线程同步是什么? 
在多线程程序下,同步能控制对共享资源的访问。如果没有同步,当一个 Java 线程在修改一个共享变量时,另外一个线程正在使用或者更新同一个变量,这样容易导致程序出现错误的结果。 

1.解释实现多线程的几种方法? 
一 Java 线程可以实现 Runnable 接口或者继承 Thread 类来实现,当你打算多重继承时,优先选择实现 Runnable。 

2.Thread.start ()与 Thread.run ()有什么区别? 
Thread.start ()方法(native)启动线程,使之进入就绪状态,当 cpu 分配时间该线程时,由 JVM 调度执行 run ()方法。 

3.为什么需要 run ()和 start ()方法,我们可以只用 run ()方法来完成任务吗? 
我们需要 run ()&start ()这两个方法是因为 JVM 创建一个单独的线程不同于普通方法的调用,所以这项工作由线程的 start 方法来完成,start 由本地方法实现,需要显示地被调用,使用这俩个方法的另外一个好处是任何一个对象都可以作为线程运行,只要实现了 Runnable 接口,这就避免因继承了 Thread 类而造成的 Java 的多继承问题。 
4.什么是 ThreadLocal 类,怎么使用它? 
ThreadLocal 是一个线程级别的局部变量,并非“本地线程”。ThreadLocal 为每个使用该变量的线程提供了一个独立的变量副本,每个线程修改副本时不影响其它线程对象的副本(译者注)。 
下面是线程局部变量(ThreadLocal variables)的关键点: 
一个线程局部变量(ThreadLocal variables)为每个线程方便地提供了一个单独的变量。 
ThreadLocal 实例通常作为静态的私有的(private static)字段出现在一个类中,这个类用来关联一个线程。 
当多个线程访问 ThreadLocal 实例时,每个线程维护 ThreadLocal 提供的独立的变量副本。 
常用的使用可在 DAO 模式中见到,当 DAO 类作为一个单例类时,数据库链接(connection)被每一个线程独立的维护,互不影响。(基于线程的单例) 

 

7.在静态方法上使用同步时会发生什么事? 
同步静态方法时会获取该类的“Class”对象,所以当一个线程进入同步的静态方法中时,线程监视器获取类本身的对象锁,其它线程不能进入这个类的任何静态同步方法。它不像实例方法,因为多个线程可以同时访问不同实例同步实例方法。 

8.当一个同步方法已经执行,线程能够调用对象上的非同步实例方法吗? 
可以,一个非同步方法总是可以被调用而不会有任何问题。实际上,Java 没有为非同步方法做任何检查,锁对象仅仅在同步方法或者同步代码块中检查。如果一个方法没有声明为同步,即使你在使用共享数据 Java 照样会调用,而不会做检查是否安全,所以在这种情况下要特别小心。一个方法是否声明为同步取决于临界区访问(critial section access),如果方法不访问临界区(共享资源或者数据结构)就没必要声明为同步的。 

下面有一个示例说明:Common 类有两个方法 synchronizedMethod1()和 method1(),MyThread 类在独立的线程中调用这两个方法。 

Java代码  收藏代码
  1. public class Common {  
  2.   
  3. public synchronized void synchronizedMethod1() {  
  4. System.out.println (“synchronizedMethod1 called”);  
  5. try {  
  6. Thread.sleep (1000);  
  7. catch (InterruptedException e) {  
  8. e.printStackTrace ();  
  9. }  
  10. System.out.println (“synchronizedMethod1 done”);  
  11. }  
  12. public void method1() {  
  13. System.out.println (“Method 1 called”);  
  14. try {  
  15. Thread.sleep (1000);  
  16. catch (InterruptedException e) {  
  17. e.printStackTrace ();  
  18. }  
  19. System.out.println (“Method 1 done”);  
  20. }  
  21. }  
  22. public class MyThread extends Thread {  
  23. private int id = 0;  
  24. private Common common;  
  25.   
  26. public MyThread (String name, int no, Common object) {  
  27. super(name);  
  28. common = object;  
  29. id = no;  
  30. }  
  31.   
  32. public void run () {  
  33. System.out.println (“Running Thread” + this.getName ());  
  34. try {  
  35. if (id == 0) {  
  36. common.synchronizedMethod1();  
  37. else {  
  38. common.method1();  
  39. }  
  40. catch (Exception e) {  
  41. e.printStackTrace ();  
  42. }  
  43. }  
  44.   
  45. public static void main (String[] args) {  
  46. Common c = new Common ();  
  47. MyThread t1 = new MyThread (“MyThread-1″, 0, c);  
  48. MyThread t2 = new MyThread (“MyThread-2″, 1, c);  
  49. t1.start ();  
  50. t2.start ();  
  51. }  
  52. }  


这里是程序的输出: 

Java代码  收藏代码
  1. Running ThreadMyThread-1  
  2. synchronizedMethod1 called  
  3. Running ThreadMyThread-2  
  4. Method 1 called  
  5. synchronizedMethod1 done  
  6. Method 1 done  

结果表明即使 synchronizedMethod1()方法执行了,method1()也会被调用。 

9.在一个对象上两个线程可以调用两个不同的同步实例方法吗?
不能,因为一个对象已经同步了实例方法,线程获取了对象的对象锁。所以只有执行完该方法释放对象锁后才能执行其它同步方法。看下面代码示例非常清晰:Common 类有 synchronizedMethod1()和 synchronizedMethod2()方法,MyThread 调用这两个方法。 

Java代码  收藏代码
  1. public class Common {  
  2. public synchronized void synchronizedMethod1() {  
  3. System.out.println (“synchronizedMethod1 called”);  
  4. try {  
  5. Thread.sleep (1000);  
  6. catch (InterruptedException e) {  
  7. e.printStackTrace ();  
  8. }  
  9. System.out.println (“synchronizedMethod1 done”);  
  10. }  
  11.   
  12. public synchronized void synchronizedMethod2() {  
  13. System.out.println (“synchronizedMethod2 called”);  
  14. try {  
  15. Thread.sleep (1000);  
  16. catch (InterruptedException e) {  
  17. e.printStackTrace ();  
  18. }  
  19. System.out.println (“synchronizedMethod2 done”);  
  20. }  
  21. }  
  22. public class MyThread extends Thread {  
  23. private int id = 0;  
  24. private Common common;  
  25.   
  26. public MyThread (String name, int no, Common object) {  
  27. super(name);  
  28. common = object;  
  29. id = no;  
  30. }  
  31.   
  32. public void run () {  
  33. System.out.println (“Running Thread” + this.getName ());  
  34. try {  
  35. if (id == 0) {  
  36. common.synchronizedMethod1();  
  37. else {  
  38. common.synchronizedMethod2();  
  39. }  
  40. catch (Exception e) {  
  41. e.printStackTrace ();  
  42. }  
  43. }  
  44.   
  45. public static void main (String[] args) {  
  46. Common c = new Common ();  
  47. MyThread t1 = new MyThread (“MyThread-1″, 0, c);  
  48. MyThread t2 = new MyThread (“MyThread-2″, 1, c);  
  49. t1.start ();  
  50. t2.start ();  
  51. }  
  52. }  


10.什么是死锁 
死锁就是两个或两个以上的线程被无限的阻塞,线程之间相互等待所需资源。这种情况可能发生在当两个线程尝试获取其它资源的锁,而每个线程又陷入无限等待其它资源锁的释放,除非一个用户进程被终止。就 JavaAPI 而言,线程死锁可能发生在一下情况。 
当两个线程相互调用 Thread.join () 
当两个线程使用嵌套的同步块,一个线程占用了另外一个线程必需的锁,互相等待时被阻塞就有可能出现死锁。 
11.什么是线程饿死,什么是活锁? 
线程饿死和活锁虽然不想是死锁一样的常见问题,但是对于并发编程的设计者来说就像一次邂逅一样。 
当所有线程阻塞,或者由于需要的资源无效而不能处理,不存在非阻塞线程使资源可用。JavaAPI 中线程活锁可能发生在以下情形: 
当所有线程在程序中执行 Object.wait (0),参数为 0 的 wait 方法。程序将发生活锁直到在相应的对象上有线程调用 Object.notify ()或者 Object.notifyAll ()。 当所有线程卡在无限循环中。

相关连接:

http://blog.csdn.net/dongwujing/article/details/7647858

http://blog.csdn.net/walkingmanc/article/details/7004826

http://www.blogjava.net/hankchen/archive/2009/12/29/307680.html

分享到:
评论

相关推荐

    多线程面试题

    本文将围绕“多线程面试题”这一主题,深入探讨相关概念、技术及其应用。 1. **线程的概念**:线程是程序执行的最小单位,一个进程可以有多个线程同时执行任务,提高了程序的运行效率。 2. **Java中的线程创建方式...

    史上最全 Java 多线程面试题及答案

    了解这些核心概念后,开发者可以更好地应对Java多线程面试中可能出现的问题,同时也能在实际项目中灵活运用多线程技术,提升程序性能。多线程编程虽然复杂,但掌握好相关的工具和原理,就能有效地解决并发问题,编写...

    java多线程面试题和答案

    以下是一些关于Java多线程的面试题及其答案,涵盖了基础概念、并发控制、线程安全以及性能优化等方面。 1. **什么是Java多线程?** 多线程是指在单个程序中同时执行多个线程,这样可以提高应用程序的效率和响应...

    java经典多线程面试题

    以下是一些经典的多线程面试题知识点: 1. Java中的线程状态有哪些? - 新建状态(New):线程对象创建后,但尚未启动。 - 就绪状态(Runnable):处于就绪状态的线程随时可能被CPU调度执行。 - 运行状态...

    2022java面试题、JVM面试题、多线程面试题、并发编程、Redis面试题、MySQL面试题、Java2022面试题

    2022java面试题、JVM面试题、多线程面试题、并发编程、Redis面试题、MySQL面试题、Java2022面试题、Netty面试题、Elasticsearch面试题、Tomcat面试题、Dubbo面试题、Kafka面试题、Linux面试题、2021面试题、java面试...

    java多线程面试题59题集合

    以下是对Java多线程面试题59题集合中可能涉及的一些关键知识点的详细解析。 1. **线程的创建方式** - 继承Thread类:创建一个新的类,该类继承自Thread类,并重写其run()方法。 - 实现Runnable接口:创建一个实现...

    10万字总结java面试题和答案(八股文之一)Java面试题指南

    多线程&并发面试题 JVM面试题 Mysql面试题 Redis面试题 Memcached面试题 MongoDB面试题 Spring面试题 Spring Boot面试题 Spring Cloud面试题 RabbitMQ面试题 Dubbo 面试题 MyBatis 面试题 ZooKeeper 面试题 数据结构...

    java多线程面试题

    以上知识点涵盖了多线程编程在Java中的基础理论和实际操作,包括线程的创建、运行、异常处理以及线程安全等问题,这些都是在进行Java多线程面试时常见的问题,对于理解和掌握Java多线程编程至关重要。

    Java 多线程面试题.one

    Java 多线程面试题.one

    Java面试题、JVM面试题、多线程面试题、并发编程、设计模式面试题

    Java面试题、JVM面试题、多线程面试题、并发编程、设计模式面试题、SpringBoot面试题、SpringCloud面试题、MyBatis面试题、Mysql面试题、VUE面试题、算法面试题、运维面试题。 收集汇总各行业笔试or编程题解题思路 ...

    java面试题_多线程(68题).pdf

    Java中的多线程是面试中常见的话题,涵盖了操作系统的基础概念以及Java并发库的高级特性。...了解这些概念有助于深入理解Java多线程编程,它们在面试中常常作为考察点,对于开发高效、可靠的并发应用程序至关重要。

    热门Java面试多线程面试题问答Top50共17页.pdf

    【标题】"热门Java面试多线程面试题问答Top50共17页.pdf" 提供了一份关于Java多线程面试的重要资源,涵盖了面试中可能会遇到的50个关键问题和答案,共计17页。这表明该文档深入探讨了Java编程中的并发处理和线程管理...

    Java多线程面试题

    以上知识点是Java多线程面试中常见的主题,掌握它们有助于深入理解Java并发编程,并在实际项目中编写高效、稳定的多线程代码。在准备面试时,不仅要理解这些概念,还要通过实践来加深理解,例如编写并发程序,分析和...

    15个顶级Java多线程面试题答案

    ### 15个顶级Java多线程面试题答案解析 #### 1. 如何保证线程执行顺序(T1→T2→T3) 在Java多线程编程中,有时我们需要控制线程的执行顺序。例如,有T1、T2、T3三个线程,我们希望T2在T1执行完毕后再执行,T3则需...

    个人总结40个Java多线程面试问题和答案

    Java多线程面试问题和答案总结 Java多线程是一种高级的编程技术,能够充分发挥多核CPU的优势,防止阻塞,简化模型建立,提高程序的效率和可维护性。下面是40个Java多线程面试问题和答案的总结,涵盖了多线程的基本...

    15个顶级Java多线程面试题及答案.pdf

    15个顶级Java多线程面试题及答案.pdf

Global site tag (gtag.js) - Google Analytics