精选大厂java多线程面试题50题
八股文java多线程面试题

八股文java多线程面试题Java多线程是面试中经常涉及的一个重要主题。
下面我将从不同角度回答一些与Java多线程相关的面试题。
1. 什么是线程?Java中如何创建线程?线程是程序执行的最小单位,它是进程中的一个执行流。
在Java中,有两种创建线程的方式,一种是继承Thread类,另一种是实现Runnable接口。
2. Java中如何实现线程同步?Java提供了多种实现线程同步的机制,最常用的是使用synchronized关键字。
通过在方法或代码块前添加synchronized 关键字,可以保证同一时间只有一个线程访问被同步的代码。
3. 什么是线程安全?如何保证线程安全?线程安全是指多个线程访问共享资源时,不会出现数据不一致或者异常的情况。
可以通过使用同步机制(如synchronized关键字)、使用线程安全的数据结构(如ConcurrentHashMap)或者使用原子类(如AtomicInteger)来保证线程安全。
4. 什么是死锁?如何避免死锁?死锁是指两个或多个线程无法继续执行的情况,因为每个线程都在等待其他线程释放资源。
为了避免死锁,可以使用避免策略,如避免使用多个锁,按照相同的顺序获取锁,或者使用定时锁等。
5. 什么是线程池?为什么要使用线程池?线程池是一种管理和复用线程的机制,它可以提高线程的利用率和系统的性能。
通过使用线程池,可以避免频繁创建和销毁线程的开销,提供线程的复用和管理。
6. 什么是线程间通信?Java中如何实现线程间通信?线程间通信是指多个线程之间进行信息的传递和共享资源的协调。
在Java中,可以使用wait()、notify()和notifyAll()方法来实现线程间的等待和唤醒机制。
7. 什么是线程的生命周期?Java中线程的生命周期有哪些状态?线程的生命周期包括五个状态,新建状态、就绪状态、运行状态、阻塞状态和死亡状态。
线程会依次经历这些状态,直到最终结束。
8. 什么是线程调度?Java中如何进行线程调度?线程调度是指操作系统决定哪个线程可以执行的过程。
JAVA并发多线程的面试问题及答案

JAVA并发多线程的面试问题及答案多线程和并发问题是Java技术面试中面试官比较喜欢问的问题之一。
在这里,从面试的角度列出了大部分重要的问题,但是你仍然应该牢固的掌握Java多线程基础知识来对应日后碰到的问题。
下面就由为大家介绍一下JAVA并发多线程的面试问题及答案的文章,欢迎阅读。
JAVA并发多线程的面试问题及答案篇11)现在有T1、T2、T3三个线程,你怎样保证T2在T1执行完后执行,T3在T2执行完后执行?这个线程问题通常会在第一轮或电话面试阶段被问到后的是检测你对〃join”方法是否熟悉。
这个多线程问题比较简单,可以用join 方法实现。
2)在Java中Lock接口比synchronized块的优势是什么?你需要实现一个高效的缓存,它允许多个用户读,但只允许一个用户写,以此来保持它的完整性,你会怎样去实现它?lock接口在多线程和并发编程中最大的优势是它们为读和写分别提供了锁,它能满足你写像ConcurrentHashM叩这样的高性能数据结构和有条件的阻塞。
Java线程面试的问题越来越会根据面试者的回答来提问。
我强烈建议在你去参加多线程的面试之前认真读一下Locks,因为当前其大量用于构建电子交易终统的客户端缓存和交易连接空间。
3)在java中wait和sleep方法的不同通常会在电话面试中经常被问到的Java线程面试问题。
最大的不同是在等待时wait会释放锁,而sleep 一直持有锁。
Wait通常被用于线程间交互,sleep通常被用于暂停执行。
4)用Java实现阻塞队列。
这是一个相对艰难的多线程面试问题,它能达到很多的目的。
第一,它可以检测侯选者是否能实际的用Java线程写程序;第二,可以检测侯选者对并发场景的理解,并且你可以根据这个问很多问题。
如果他用wait ()和notify()方法来实现阻塞队列,你可以要求他用最新的Java 5中的并发类来再写一次。
JAVA并发多线程的面试问题及答案篇21)用Java写代码来解决生产者;;消费者问题。
多线程常见面试题及答案

多线程常见⾯试题及答案1、如何在Java中实现线程(4种)?1.继承Thread类,重写run⽅法(其实Thread类本⾝也实现了Runnable接⼝)2.实现Runnable接⼝,重写run⽅法3.实现Callable接⼝,重写call⽅法(有返回值)4.使⽤线程池(有返回值)2、在具体多线程编程实践中,如何选⽤Runnable还是Thread?Java中实现多线程有两种⽅法:继承Thread类、实现Runnable接⼝,在程序开发中只要是多线程,肯定永远以实现Runnable接⼝为主,因为实现Runnable接⼝相⽐继承Thread类有如下优势:1、可以避免由于Java的单继承特性⽽带来的局限;2、增强程序的健壮性,代码能够被多个线程共享,代码与数据是独⽴的;适合多个相同程序代码的线程区处理同⼀资源的情况。
3、Thread类中的start()和run()⽅法有什么区别?start()⽅法来启动线程,真正实现了多线程运⾏,这时⽆需等待run⽅法体代码执⾏完毕⽽直接继续执⾏下⾯的代码:通过调⽤Thread类的start()⽅法来启动⼀个线程,这时此线程是处于就绪状态,并没有运⾏。
然后通过此Thread类调⽤⽅法run()来完成其运⾏操作的,这⾥⽅法run()称为线程体,它包含了要执⾏的这个线程的内容,Run⽅法运⾏结束,此线程终⽌,⽽CPU再运⾏其它线程。
run()⽅法当作普通⽅法的⽅式调⽤,程序还是要顺序执⾏,还是要等待run⽅法体执⾏完毕后才可继续执⾏下⾯的代码:⽽如果直接⽤run⽅法,这只是调⽤⼀个⽅法⽽已,程序中依然只有主线程–这⼀个线程,其程序执⾏路径还是只有⼀条,这样就没有达到多线程的⽬的。
4、Java中Runnable和Callable有什么不同相同点:1. 两者都是接⼝;(废话)2. 两者都可⽤来编写多线程程序;3. 两者都需要调⽤Thread.start()启动线程;不同点:1. 两者最⼤的不同点是:实现Callable接⼝的任务线程能返回执⾏结果;⽽实现Runnable接⼝的任务线程不能返回结果;2. Callable接⼝的call()⽅法允许抛出异常;⽽Runnable接⼝的run()⽅法的异常只能在内部消化,不能继续上抛;注意点:Callable接⼝⽀持返回执⾏结果,此时需要调⽤FutureTask.get()⽅法实现,此⽅法会阻塞主线程直到获取‘将来’结果;当不调⽤此⽅法时,主线程不会阻塞!5、如何避免死锁?1. 加锁顺序按照顺序加锁是⼀种有效的死锁预防机制。
java高并发面试题

java高并发面试题Java高并发面试题一共包含以下几个问题:问题一:什么是线程安全?如何保证线程安全?线程安全是指多线程环境下,多个线程同时访问共享资源时,不会出现数据不一致或者访问异常的情况。
为了保证线程安全,可以采取以下几种方式:1. 使用同步(Synchronized)关键字:通过在多个线程中对共享资源进行同步互斥访问,即在一个线程访问共享资源时,其他线程无法同时访问,从而保证线程安全。
2. 使用Lock锁:通过Lock接口提供的lock()和unlock()方法对共享资源进行加锁和解锁,实现线程安全。
3. 使用原子类:Java.util.concurrent.atomic包提供了一系列的原子类,如AtomicInteger、AtomicLong等,通过这些原子类的方法操作变量,保证了原子性和线程安全。
问题二:什么是线程池?为什么要使用线程池?请分析线程池的优点和适用场景。
线程池是一种管理和复用线程的机制。
线程池中包含了多个线程,这些线程可以重复利用,避免了线程的频繁创建和销毁,提高了系统的性能和响应速度。
使用线程池的优点包括:1. 减少线程创建和销毁的开销:线程的创建和销毁都是比较昂贵的操作,使用线程池可以复用已经存在的线程,降低了创建和销毁线程的开销。
2. 控制线程数量:线程池可以根据系统的负载情况动态调整线程数量,控制线程的并发数量,避免因为线程过多而导致系统资源耗尽。
3. 提高系统响应速度:线程池可以通过线程的复用和任务的排队执行,提高了系统的响应速度,特别是在处理大量并发请求的场景下。
适用场景:1. Web服务器:在Web服务器中,用户的请求可以由线程池中的线程来处理,提高了系统的并发能力。
2. 数据库连接池:数据库连接是一种昂贵的资源,线程池可以维护一定数量的数据库连接,通过复用连接的方式提高数据库访问的效率。
问题三:什么是锁?Java中提供了哪几种锁,分别有什么特点?锁是一种用于控制多线程并发访问共享资源的机制。
java面试题库java面试题目及答案(3篇)

第1篇一、基础知识1. Java简介题目:请简述Java的基本特点。
答案:- 简单易学:Java设计之初就考虑了易学性,使用面向对象编程。
- 原生跨平台:Java通过JVM(Java虚拟机)实现跨平台运行。
- 安全性:Java提供了强大的安全机制,如沙箱安全模型。
- 体系结构中立:Java不依赖于特定的硬件或操作系统。
- 高效:Java的运行速度接近C/C++。
- 多线程:Java内置多线程支持,便于实现并发处理。
- 动态性:Java在运行时可以进行扩展和修改。
2. Java虚拟机题目:请解释Java虚拟机(JVM)的作用。
答案:JVM是Java程序的运行环境,其主要作用包括:- 将Java字节码转换为本地机器码。
- 管理内存,包括堆、栈、方法区等。
- 提供垃圾回收机制。
- 管理线程和同步。
3. Java内存模型题目:请简述Java内存模型的组成。
答案:Java内存模型主要由以下部分组成:- 堆(Heap):存储对象实例和数组。
- 栈(Stack):存储局部变量和方法调用。
- 方法区(Method Area):存储类信息、常量、静态变量等。
- 本地方法栈(Native Method Stack):存储本地方法调用的相关数据。
- 程序计数器(Program Counter Register):存储线程的当前指令地址。
4. Java关键字题目:请列举并解释Java中的几个关键字。
答案:- `public`:表示访问权限为公开。
- `private`:表示访问权限为私有。
- `protected`:表示访问权限为受保护。
- `static`:表示属于类本身,而非对象实例。
- `final`:表示常量或方法不能被修改。
- `synchronized`:表示线程同步。
- `transient`:表示数据在序列化时不会被持久化。
二、面向对象编程5. 类和对象题目:请解释类和对象之间的关系。
答案:类是对象的模板,对象是类的实例。
java模拟面试题目(3篇)

第1篇一、Java基础知识1. 请简述Java语言的特点。
2. 什么是Java虚拟机(JVM)?它有什么作用?3. 什么是Java的内存模型?请解释Java内存模型中的几个关键概念:堆、栈、方法区、程序计数器、本地方法栈。
4. 什么是Java中的反射机制?请举例说明反射在Java中的应用。
5. 什么是Java中的泛型?请解释泛型的原理和作用。
6. 请简述Java中的四种访问控制符:public、protected、default、private。
7. 什么是Java中的继承和多态?请举例说明继承和多态在实际开发中的应用。
8. 什么是Java中的封装?请举例说明封装在实际开发中的应用。
9. 什么是Java中的接口和抽象类?它们之间有什么区别?10. 什么是Java中的异常处理?请解释try-catch-finally语句的执行顺序。
二、Java集合框架1. 请列举Java集合框架中的常用集合类及其特点。
2. 请简述ArrayList、LinkedList、HashMap、HashSet的区别。
3. 什么是Java中的泛型集合?请举例说明泛型集合的应用。
4. 什么是Java中的迭代器(Iterator)和枚举器(Enum)?请比较它们的区别。
5. 什么是Java中的List、Set、Map的遍历方法?6. 请解释Java中的ArrayList和LinkedList的内部实现原理。
7. 什么是Java中的HashMap的扩容机制?8. 什么是Java中的HashSet的内部实现原理?9. 请解释Java中的线程安全集合类,如CopyOnWriteArrayList、ConcurrentHashMap。
三、Java多线程与并发1. 什么是Java中的线程?请解释线程的创建、调度和同步。
2. 请简述Java中的线程状态,如新建、就绪、运行、阻塞、等待、超时等待、终止。
3. 什么是Java中的同步机制?请解释synchronized关键字的作用。
最全多线程经典面试题和答案

最全多线程经典⾯试题和答案Java实现线程有哪⼏种⽅式?1、继承Thread类实现多线程2、实现Runnable接⼝⽅式实现多线程3、使⽤ExecutorService、Callable、Future实现有返回结果的多线程多线程同步有哪⼏种⽅法?Synchronized关键字,Lock锁实现,分布式锁等。
Runnable和Thread⽤哪个好?Java不⽀持类的多重继承,但允许你实现多个接⼝。
所以如果你要继承其他类,也为了减少类之间的耦合性,Runnable会更好。
Java中notify和notifyAll有什么区别?notify()⽅法不能唤醒某个具体的线程,所以只有⼀个线程在等待的时候它才有⽤武之地。
⽽notifyAll()唤醒所有线程并允许他们争夺锁确保了⾄少有⼀个线程能继续运⾏。
为什么wait/notify/notifyAll这些⽅法不在thread类⾥⾯?这是个设计相关的问题,它考察的是⾯试者对现有系统和⼀些普遍存在但看起来不合理的事物的看法。
回答这些问题的时候,你要说明为什么把这些⽅法放在Object类⾥是有意义的,还有不把它放在Thread类⾥的原因。
⼀个很明显的原因是JAVA提供的锁是对象级的⽽不是线程级的,每个对象都有锁,通过线程获得。
如果线程需要等待某些锁那么调⽤对象中的wait()⽅法就有意义了。
如果wait()⽅法定义在Thread类中,线程正在等待的是哪个锁就不明显了。
简单的说,由于wait,notify和notifyAll都是锁级别的操作,所以把他们定义在Object类中因为锁属于对象。
为什么wait和notify⽅法要在同步块中调⽤?主要是因为Java API强制要求这样做,如果你不这么做,你的代码会抛出IllegalMonitorStateException异常。
还有⼀个原因是为了避免wait 和notify之间产⽣竞态条件。
什么是死锁?如何避免死锁?死锁就是两个线程相互等待对⽅释放对象锁。
校招大厂面试题及答案

校招大厂面试题及答案### 校招大厂面试题及答案#### 技术岗位面试题1. 数据结构与算法- 题目:请解释什么是二叉搜索树,并给出插入操作的步骤。
- 答案:二叉搜索树(BST)是一种特殊的二叉树,其中每个节点的值都大于或等于其左子树中的所有节点的值,并且小于或等于其右子树中的所有节点的值。
插入操作首先从根节点开始,比较待插入值与当前节点的值。
如果待插入值小于当前节点的值,则向左子树递归;如果大于,则向右子树递归。
当找到一个空位时,将新节点插入。
2. 编程语言特性- 题目:Java中的接口和抽象类有什么区别?- 答案:Java中的接口(Interface)可以定义方法但不能实现它们,而抽象类(Abstract Class)可以包含抽象方法和具体方法。
一个类可以实现多个接口,但只能继承一个抽象类。
接口主要用于定义能力,而抽象类用于代码复用。
3. 操作系统- 题目:进程和线程的区别是什么?- 答案:进程是操作系统进行资源分配和调度的一个独立单位,拥有独立的内存空间。
线程是进程中的一个执行单元,是CPU调度和分派的基本单位,线程共享所属进程的资源。
4. 计算机网络- 题目:TCP和UDP协议的主要区别是什么?- 答案:TCP(传输控制协议)是一个面向连接的、可靠的、基于字节流的传输层通信协议,它确保数据的有序传输和错误恢复。
UDP(用户数据报协议)是一个无连接的协议,它允许应用程序发送数据报,但不保证数据报的顺序或可靠性。
#### 非技术岗位面试题1. 市场营销- 题目:如何评估一个营销活动的成功?- 答案:评估营销活动的成功可以通过多种指标,如品牌知名度的提升、目标受众的参与度、销售量的增加、顾客满意度以及营销活动的投资回报率(ROI)等。
2. 人力资源- 题目:在招聘过程中,如何确保多样性和包容性?- 答案:确保多样性和包容性可以通过制定公平的招聘政策、提供无偏见的职位描述、实施盲选流程、提供培训以提高面试官的无意识偏见意识,以及创建一个支持多样性的工作环境。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
Java多线程50题1)什么是线程?线程是操作系统能够进行运算调度的最小单位,它被包含在进程之中,是进程中的实际运作单位。
程序员可以通过它进行多处理器编程,你可以使用多线程对运算密集型任务提速。
比如,如果一个线程完成一个任务要100毫秒,那么用十个线程完成改任务只需10毫秒。
2)线程和进程有什么区别?线程是进程的子集,一个进程可以有很多线程,每条线程并行执行不同的任务。
不同的进程使用不同的内存空间,而所有的线程共享一片相同的内存空间。
别把它和栈内存搞混,每个线程都拥有单独的栈内存用来存储本地数据。
更多详细信息请点击这里。
3)如何在Java中实现线程?ng.Thread类的实例就是一个线程但是它需要调用ng.Runnable接口来执行,由于线程类本身就是调用的Runnable接口所以你可以继承ng.Thread类或者直接调用Runnable接口来重写run()方法实现线程。
4)Thread类中的start()和run()方法有什么区别?这个问题经常被问到,但还是能从此区分出面试者对Java线程模型的理解程度。
start()方法被用来启动新创建的线程,而且start()内部调用了run()方法,这和直接调用run()方法的效果不一样。
当你调用run()方法的时候,只会是在原来的线程中调用,没有新的线程启动,start()方法才会启动新线程。
5)Java中Runnable和Callable有什么不同?Runnable和Callable都代表那些要在不同的线程中执行的任务。
Runnable从JDK1.0开始就有了,Callable是在JDK1.5增加的。
它们的主要区别是Callable的call()方法可以返回值和抛出异常,而Runnable的run()方法没有这些功能。
Callable可以返回装载有计算结果的Future对象。
6)Java内存模型是什么?Java内存模型规定和指引Java程序在不同的内存架构、CPU 和操作系统间有确定性地行为。
它在多线程的情况下尤其重要。
Java内存模型对一个线程所做的变动能被其它线程可见提供了保证,它们之间是先行发生关系。
●线程内的代码能够按先后顺序执行,这被称为程序次序规则。
●对于同一个锁,一个解锁操作一定要发生在时间上后发生的另一个锁定操作之前,也叫做管程锁定规则。
●前一个对Volatile的写操作在后一个volatile的读操作之前,也叫volatile变量规则。
●一个线程内的任何操作必需在这个线程的start()调用之后,也叫作线程启动规则。
●一个线程的所有操作都会在线程终止之前,线程终止规则。
●一个对象的终结操作必需在这个对象构造完成之后,也叫对象终结规则。
●可传递性7)Java中的volatile变量是什么?volatile是一个特殊的修饰符,只有成员变量才能使用它。
在Java并发程序缺少同步类的情况下,多线程对成员变量的操作对其它线程是透明的。
volatile变量可以保证下一个读取操作会在前一个写操作之后发生,就是上一题的volatile变量规则。
8)什么是线程安全?Vector是一个线程安全类吗?如果你的代码所在的进程中有多个线程在同时运行,而这些线程可能会同时运行这段代码。
如果每次运行结果和单线程运行的结果是一样的,而且其他的变量的值也和预期的是一样的,就是线程安全的。
一个线程安全的计数器类的同一个实例对象在被多个线程使用的情况下也不会出现计算失误。
很显然你可以将集合类分成两组,线程安全和非线程安全的。
Vector是用同步方法来实现线程安全的,而和它相似的ArrayList不是线程安全的。
9)Java中如何停止一个线程?Java提供了很丰富的API但没有为停止线程提供API。
JDK1.0本来有一些像stop(),suspend()和resume()的控制方法但是由于潜在的死锁威胁因此在后续的JDK版本中他们被弃用了,之后JavaAPI 的设计者就没有提供一个兼容且线程安全的方法来停止一个线程。
当run()或者call()方法执行完的时候线程会自动结束,如果要手动结束一个线程,你可以用volatile布尔变量来退出run()方法的循环或者是取消任务来中断线程。
10)一个线程运行时发生异常会怎样?如果异常没有被捕获该线程将会停止执行。
Thread.UncaughtExceptionHandler是用于处理未捕获异常造成线程突然中断情况的一个内嵌接口。
当一个未捕获异常将造成线程中断的时候JVM会使用Thread.getUncaughtExceptionHandler()来查询线程的UncaughtExceptionHandler并将线程和异常作为参数传递给handler的uncaughtException()方法进行处理。
11)如何在两个线程间共享数据?可以通过共享对象来实现这个目的,或者是使用像阻塞队列这样并发的数据结构。
用wait和notify方法实现了生产者消费者模型。
12)J ava中notify和notifyAll有什么区别?notify()方法不能唤醒某个具体的线程,所以只有一个线程在等待的时候它才有用武之地。
而notifyAll()唤醒所有线程并允许他们争夺锁确保了至少有一个线程能继续运行。
13)为什么wait,notify和notifyAll这些方法不在thread类里面?JAVA提供的锁是对象级的而不是线程级的,每个对象都有锁,通过线程获得。
如果线程需要等待某些锁那么调用对象中的wait()方法就有意义了。
如果wait()方法定义在Thread类中,线程正在等待的是哪个锁就不明显了。
简单的说,由于wait,notify和notifyAll都是锁级别的操作,所以把他们定义在Object类中因为锁属于对象。
14)什么是ThreadLocal变量?ThreadLocal是Java里一种特殊的变量。
每个线程都有一个ThreadLocal就是每个线程都拥有了自己独立的一个变量,竞争条件被彻底消除了。
它是为创建代价高昂的对象获取线程安全的好方法,比如你可以用ThreadLocal让SimpleDateFormat变成线程安全的,因为那个类创建代价高昂且每次调用都需要创建不同的实例所以不值得在局部范围使用它,如果为每个线程提供一个自己独有的变量拷贝,将大大提高效率。
首先,通过复用减少了代价高昂的对象的创建个数。
其次,你在没有使用高代价的同步或者不变性的情况下获得了线程安全。
线程局部变量的另一个不错的例子是ThreadLocalRandom类,它在多线程环境中减少了创建代价高昂的Random对象的个数。
15)什么是FutureTask?在Java并发程序中FutureTask表示一个可以取消的异步运算。
它有启动和取消运算、查询运算是否完成和取回运算结果等方法。
只有当运算完成的时候结果才能取回,如果运算尚未完成get方法将会阻塞。
一个FutureTask对象可以对调用了Callable和Runnable的对象进行包装,由于FutureTask也是调用了Runnable接口所以它可以提交给Executor来执行。
16)为什么wait和notify方法要在同步块中调用?主要是因为JavaAPI强制要求这样做,如果你不这么做,你的代码会抛出IllegalMonitorStateException异常。
还有一个原因是为了避免wait和notify之间产生竞态条件。
17)为什么你应该在循环中检查等待条件?处于等待状态的线程可能会收到错误警报和伪唤醒,如果不在循环中检查等待条件,程序就会在没有满足结束条件的情况下退出。
因此,当一个等待线程醒来时,不能认为它原来的等待状态仍然是有效的,在notify()方法调用之后和等待线程醒来之前这段时间它可能会改变。
这就是在循环中使用wait()方法效果更好的原因。
18)J ava中堆和栈有什么不同?为什么把这个问题归类在多线程和并发面试题里?因为栈是一块和线程紧密相关的内存区域。
每个线程都有自己的栈内存,用于存储本地变量,方法参数和栈调用,一个线程中存储的变量对其它线程是不可见的。
而堆是所有线程共享的一片公用内存区域。
对象都在堆里创建,为了提升效率线程会从堆中弄一个缓存到自己的栈,如果多个线程使用该变量就可能引发问题,这时volatile变量就可以发挥作用了,它要求线程从主存中读取变量的值。
19)什么是线程池?为什么要使用它?创建线程要花费昂贵的资源和时间,如果任务来了才创建线程那么响应时间会变长,而且一个进程能创建的线程数有限。
为了避免这些问题,在程序启动的时候就创建若干线程来响应处理,它们被称为线程池,里面的线程叫工作线程。
从JDK1.5开始,JavaAPI提供了Executor框架让你可以创建不同的线程池。
比如单线程池,每次处理一个任务;数目固定的线程池或者是缓存线程池(一个适合很多生存期短的任务的程序的可扩展线程池)。
20)如何避免死锁?死锁是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去。
这是一个严重的问题,因为死锁会让你的程序挂起无法完成任务,死锁的发生必须满足以下四个条件:●互斥条件:一个资源每次只能被一个进程使用。
●请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放。
●不剥夺条件:进程已获得的资源,在末使用完之前,不能强行剥夺。
●循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系。
避免死锁最简单的方法就是阻止循环等待条件,将系统中所有的资源设置标志位、排序,规定所有的进程申请资源必须以一定的顺序(升序或降序)做操作来避免死锁。
21)怎么检测一个线程是否拥有锁?在ng.Thread中有一个方法叫holdsLock(),它返回true 如果当且仅当当前线程拥有某个具体对象的锁。
22)J VM中哪个参数是用来控制线程的栈堆栈小的-Xss参数用来控制线程的堆栈大小。
23)J ava中synchronized和ReentrantLock有什么不同?Java在过去很长一段时间只能通过synchronized关键字来实现互斥,它有一些缺点。
比如你不能扩展锁之外的方法或者块边界,尝试获取锁时不能中途取消等。
Java5通过Lock接口提供了更复杂的控制来解决这些问题。
ReentrantLock类实现了Lock,它拥有与synchronized相同的并发性和内存语义且它还具有可扩展性。
24)有三个线程T1,T2,T3,怎么确保它们按顺序执行?在多线程中有多种方法让线程按特定顺序执行,你可以用线程类的join()方法在一个线程中启动另一个线程,另外一个线程完成该线程继续执行。
为了确保三个线程的顺序你应该先启动最后一个(T3调用T2,T2调用T1),这样T1就会先完成而T3最后完成。