50个多线程面试题

下面是Java线程相关的热门面试题,你可以用它来好好准备面试。

  1. 什么是线程?

       程序执行的基本单位。

      2.什么是线程安全和线程不安全?

            线程安全:

            指多个线程在执行同一段代码的时候采用加锁机制,使每次的执行结果和单线程执行的结果都是一样的,不存在执行程序时出现意外结果。

            线程不安全:

           是指不提供加锁机制保护,有可能出现多个线程先后更改数据造成所得到的数据是脏数据。

        当我们在做压测或并发测试时,经常会遇到此问题

       举例说明:假设售票系统有1000张票,A和B同时来买票,如果是线程不安全,

       那么可能售票系统可能出现1000-1去同时执行的情况,最终结果是A和B都买完后剩下999张票,而不是998张。

线程安全:

     指多个线程在执行同一段代码的时候采用加锁机制,使每次的执行结果和单线程执行的结果都是一样的,不存在执行程序时出现意外结果。

     线程不安全:

     是指不提供加锁机制保护,有可能出现多个线程先后更改数据造成所得到的数据是脏数据

  1. 什么是自旋锁?

自旋锁(spinlock):是指当一个线程在获取锁的时候,如果锁已经被其它线程获取,那么该线程将循环等待,然后不断的判断锁是否能够被成功获取,直到获取到锁才会退出循环。

获取锁的线程一直处于活跃状态,但是并没有执行任何有效的任务,使用这种锁会造成busy-waiting。

  1. 什么是Java内存模型?

 

  1. 什么是CAS?

.CAS的含义

CAS是compare and swap的缩写,即我们所说的比较交换。cas是一种基于锁的操作,而且是乐观锁。

在java中锁分为乐观锁和悲观锁。悲观锁是将资源锁住,等一个之前获得锁的线程释放锁之后,下一个线程才可以访问。

而乐观锁采取了一种宽泛的态度,通过某种方式不加锁来处理资源,比如通过给记录加version来获取数据,性能较悲观锁有很大的提高。

CAS 操作包含三个操作数 —— 内存位置(V)、预期原值(A)和新值(B)。如果内存地址里面的值和A的值是一样的,

那么就将内存里面的值更新成B。CAS是通过无限循环来获取数据的,若果在第一轮循环中,a线程获取地址里面的值被b线程修改了,

那么a线程需要自旋,到下次循环才有可能机会执行。

CAS的问题

①.CAS容易造成ABA问题。一个线程a将数值改成了b,接着又改成了a,此时CAS认为是没有变化,其实是已经变化过了,

而这个问题的解决方案可以使用版本号标识,每操作一次version加1。在java5中,已经提供了AtomicStampedReference来解决问题。

②.CAS造成CPU利用率增加。之前说过了CAS里面是一个循环判断的过程,如果线程一直没有获取到状态,cpu资源会一直被占用。

 

 


 

  1. 什么是乐观锁和悲观锁?

 

  1. 什么是AQS?
  2. 什么是原子操作?在Java Concurrency API中有哪些原子类(atomic classes)?
  3. 什么是Executors框架?
  4. 什么是阻塞队列?如何使用阻塞队列来实现生产者-消费者模型?
  5. 什么是Callable和Future?
  6. 什么是FutureTask?
  7. 什么是同步容器和并发容器的实现?
  8. 什么是多线程?优缺点?
  9. 什么是多线程的上下文切换?
  10. ThreadLocal的设计理念与作用?
  11. ThreadPool(线程池)用法与优势?
  12. Concurrent包里的其他东西:ArrayBlockingQueue、CountDownLatch等等。
  13. synchronized和ReentrantLock的区别?
  14. Semaphore有什么作用?
  15. Java Concurrency API中的Lock接口(Lock interface)是什么?对比同步它有什么优势?
  16. Hashtable的size()方法中明明只有一条语句”return count”,为什么还要做同步?
  17. ConcurrentHashMap的并发度是什么?
  18. ReentrantReadWriteLock读写锁的使用?
  19. CyclicBarrier和CountDownLatch的用法及区别?
  20. LockSupport工具?
  21. Condition接口及其实现原理?
  22. Fork/Join框架的理解?
  23. wait()和sleep()的区别?
  24. 线程的五个状态(五种状态,创建、就绪、运行、阻塞和死亡)?
  25. start()方法和run()方法的区别?
  26. Runnable接口和Callable接口的区别?
  27. volatile关键字的作用?
  28. Java中如何获取到线程dump文件?
  29. 线程和进程有什么区别?
  30. 线程实现的方式有几种(四种)?
  31. 高并发、任务执行时间短的业务怎样使用线程池?并发不高、任务执行时间长的业务怎样使用线程池?并发高、业务执行时间长的业务怎样使用线程池?
  32. 如果你提交任务时,线程池队列已满,这时会发生什么?
  33. 锁的等级:方法锁、对象锁、类锁?
  34. 如果同步块内的线程抛出异常会发生什么?
  35. 并发编程(concurrency)并行编程(parallellism)有什么区别?
  36. 如何保证多线程下 i++ 结果正确?
  37. 一个线程如果出现了运行时异常会怎么样?
  38. 如何在两个线程之间共享数据?
  39. 生产者消费者模型的作用是什么?
  40. 怎么唤醒一个阻塞的线程?
  41. Java中用到的线程调度算法是什么
  42. 单例模式的线程安全性?
  43. 线程类的构造方法、静态块是被哪个线程调用的?
  44. 同步方法和同步块,哪个是更好的选择?
  45. 如何检测死锁?怎么预防死锁?
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值