java面试题之多线程
Java开发工程师招聘面试题与参考回答2025年

2025年招聘Java开发工程师面试题与参考回答面试问答题(总共10个问题)第一题:请描述一下Java中的反射机制及其在Java编程中的应用场景。
答案:Java的反射机制是指在运行时,程序能够取得任何类或对象的内部信息,并且动态创建对象、调用对象的方法以及获取对象的属性。
以下是反射机制的一些关键点:1.反射机制允许在运行时动态地加载和调用类的方法。
2.反射机制可以获取类的构造方法、字段、方法和注解等信息。
3.反射机制提供了访问和修改类内部状态的能力。
应用场景:1.创建对象:通过反射机制,可以在运行时创建任意类的实例。
2.方法调用:在运行时动态调用任意对象的方法。
3.获取类信息:在运行时获取类的名称、父类、接口等信息。
4.动态代理:在实现动态代理时,通过反射机制动态创建代理对象。
5.脚本语言集成:某些脚本语言可以通过反射机制与Java代码进行交互。
解析:反射机制在Java编程中具有广泛的应用,以下是几个具体的例子:•在框架开发中,如Spring框架,反射机制被用来动态地注册和管理Bean。
•在插件系统中,反射机制允许在运行时动态加载和调用插件。
•在测试框架中,如JUnit,反射机制被用来动态调用测试方法。
•在JDBC编程中,反射机制可以用来动态创建数据库连接和执行SQL语句。
反射机制虽然功能强大,但也存在一些缺点,如性能开销大、代码难以理解等。
因此,在使用反射时,应尽量减少不必要的反射操作。
第二题:请简述Java中的多态性及其实现方式,并举例说明在Java中如何通过多态来简化代码设计。
答案:多态性是面向对象编程中的一个核心概念,它允许同一个接口或父类在不同的情况下表现出不同的行为。
在Java中,多态性主要通过继承和接口实现。
1.继承:当一个子类继承了父类后,子类对象可以调用父类的方法和属性,如果子类对父类的方法进行了重写(即子类提供了与父类方法相同签名但不同实现的方法),那么在调用该方法时,就会根据对象的实际类型来执行对应的方法。
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面试题目及答案(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校招面试题

java校招面试题一、简介Java是一种广泛应用于开发各种应用程序的编程语言。
在校招中,Java面试题通常涉及Java基础知识、面向对象编程、多线程、集合框架等方面。
本文将从这些方面总结一些常见的Java校招面试题。
二、Java基础知识1. 什么是Java虚拟机(JVM)?它的作用是什么?答:Java虚拟机(JVM)是Java的核心虚拟机,它负责将Java字节码转换为计算机可以执行的机器码。
JVM的作用是实现Java的平台无关性,使得Java程序可以跨平台运行。
2. Java中的基本数据类型有哪些?答:Java中的基本数据类型有:byte、short、int、long、float、double、boolean、char。
3. 什么是Java中的装箱和拆箱?答:装箱是将基本数据类型转换为对应的包装类类型,拆箱是将包装类类型转换为对应的基本数据类型。
例如,装箱可以将一个int类型的变量转换为Integer对象。
三、面向对象编程4. 什么是面向对象编程?请举例说明。
答:面向对象编程是一种以对象为基础,通过封装、继承和多态等机制来组织代码的编程方式。
一个典型的面向对象编程的例子是定义一个类Person,并通过创建不同的Person对象来表示不同的人。
5. 继承和多态的概念分别是什么?答:继承是指一个类(子类)继承另一个类(父类)的特性和行为。
多态是指相同的接口可以有不同的实现方式。
通过继承和多态可以使代码更加灵活和可复用。
四、多线程6. 什么是线程?线程和进程有什么区别?答:线程是程序执行中的最小单元,它可以独立运行和执行任务。
线程是进程中的一个实体,一个进程可以包含多个线程。
进程是指一个程序在执行过程中分配和管理资源的基本单位。
7. 如何创建线程?请写出一个简单的示例代码。
答:可以通过继承Thread类或实现Runnable接口来创建线程。
示例代码如下:```javapublic class MyThread extends Thread {public void run() {System.out.println("This is a thread.");}}public class Main {public static void main(String[] args) {MyThread thread = new MyThread();thread.start();}}```五、集合框架8. Java集合框架有哪些常用的类?答:Java集合框架包含了一系列接口和类,常用的类有ArrayList、LinkedList、HashSet、HashMap等。
最全多线程经典面试题和答案

最全多线程经典⾯试题和答案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之间产⽣竞态条件。
什么是死锁?如何避免死锁?死锁就是两个线程相互等待对⽅释放对象锁。
银行科技部面试题目(3篇)

第1篇一、开场白尊敬的面试官,您好!我是应聘银行科技部岗位的应聘者[您的姓名]。
非常感谢贵行给我这次面试的机会。
在此,我想先做一个简单的自我介绍。
我叫[您的姓名],毕业于[您的学校],专业是[您的专业]。
在校期间,我主修了[主要课程],对[相关技术领域]有深入的了解和实践经验。
我对银行科技部的工作充满热情,并相信自己的能力和经验能够胜任这个岗位。
以下是我为银行科技部岗位准备的一些面试题目及解析,希望能够帮助我在面试中更好地展示自己的能力和素质。
二、技术基础知识1. 问题:请简述Java中多线程的实现方式。
解析:Java中实现多线程的方式主要有两种:继承Thread类和实现Runnable接口。
继承Thread类的方式较为简单,但缺点是会产生大量重复代码。
实现Runnable接口的方式更为灵活,可以避免继承带来的单继承局限。
2. 问题:请解释一下数据库事务的ACID特性。
解析:ACID是数据库事务的四个基本特性,分别代表原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持久性(Durability)。
- 原子性:事务中的所有操作要么全部完成,要么全部不完成,不会出现中间状态。
- 一致性:事务执行后,数据库的状态必须从一个合法状态转移到另一个合法状态。
- 隔离性:并发执行的事务之间不能相互干扰,每个事务都像是独立执行一样。
- 持久性:一旦事务提交,其所做的更改就永久保存在数据库中。
3. 问题:请解释一下TCP和UDP协议的区别。
解析:TCP和UDP是两种常见的传输层协议,它们的主要区别如下:- TCP是面向连接的,UDP是无连接的;- TCP提供可靠的数据传输,UDP不保证数据传输的可靠性;- TCP的传输速度较慢,UDP的传输速度较快;- TCP适用于传输大量数据,UDP适用于传输少量数据。
三、项目经验1. 问题:请描述一下你在项目中的角色和职责。
解析:在[项目名称]项目中,我担任[你的角色]一职。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
java面试题之多线程线程或者说多线程,是我们处理多任务的强大工具。
线程和进程是不同的,每个进程都是一个独立运行的程序,拥有自己的变量,且不同进程间的变量不能共享;而线程是运行在进程内部的,每个正在运行的进程至少有一个线程,而且不同的线程之间可以在进程范围内共享数据。
也就是说进程有自己独立的存储空间,而线程是和它所属的进程内的其他线程共享一个存储空间。
线程的使用可以使我们能够并行地处理一些事情。
线程通过并行的处理给用户带来更好的使用体验,比如你使用的邮件系统(outlook、Thunderbird、foxmail等),你当然不希望它们在收取新邮件的时候,导致你连已经收下来的邮件都无法阅读,而只能等待收取邮件操作执行完毕。
这正是线程的意义所在。
实现线程的方式实现线程的方式有两种:1. 继承ng.Thread,并重写它的run()方法,将线程的执行主体放入其中。
2. 实现ng.Runnable接口,实现它的run()方法,并将线程的执行主体放入其中。
这是继承Thread类实现线程的示例:public class ThreadTest extends Thread {public void run() {// 在这里编写线程执行的主体// do something}}这是实现Runnable接口实现多线程的示例:public class RunnableTest implements Runnable {public void run() {// 在这里编写线程执行的主体// do something}}这两种实现方式的区别并不大。
继承Thread类的方式实现起来较为简单,但是继承它的类就不能再继承别的类了,因此也就不能继承别的类的有用的方法了。
而使用是想Runnable接口的方式就不存在这个问题了,而且这种实现方式将线程主体和线程对象本身分离开来,逻辑上也较为清晰,所以推荐大家更多地采用这种方式。
如何启动线程我们通过以上两种方式实现了一个线程之后,线程的实例并没有被创建,因此它们也并没有被运行。
我们要启动一个线程,必须调用方法来启动它,这个方法就是Thread类的start()方法,而不是run()方法(既不是我们继承Thread类重写的run()方法,也不是实现Runnable接口的run()方法)。
run()方法中包含的是线程的主体,也就是这个线程被启动后将要运行的代码,它跟线程的启动没有任何关系。
上面两种实现线程的方式在启动时会有所不同。
继承Thread类的启动方式:public class ThreadStartTest {public static void main(String[] args) {// 创建一个线程实例ThreadTest tt = new ThreadTest();// 启动线程tt.start();}}实现Runnable接口的启动方式:public class RunnableStartTest {public static void main(String[] args) {// 创建一个线程实例Thread t = new Thread(new RunnableTest());// 启动线程t.start();}}实际上这两种启动线程的方式原理是一样的。
首先都是调用本地方法启动一个线程,其次是在这个线程里执行目标对象的run()方法。
那么这个目标对象是什么呢?为了弄明白这个问题,我们来看看Thread类的run()方法的实现:public void run() {if (target != null) {target.run();}}当我们采用实现Runnable接口的方式来实现线程的情况下,在调用new Thread(Runnable target)构造器时,将实现Runnable接口的类的实例设置成了线程要执行的主体所属的目标对象target,当线程启动时,这个实例的run()方法就被执行了。
当我们采用继承Thread的方式实现线程时,线程的这个run()方法被重写了,所以当线程启动时,执行的是这个对象自身的run()方法。
总结起来就一句话,线程类有一个Runnable 类型的target属性,它是线程启动后要执行的run()方法所属的主体,如果我们采用的是继承Thread类的方式,那么这个target就是线程对象自身,如果我们采用的是实现Runnable接口的方式,那么这个target 就是实现了Runnable接口的类的实例。
线程的状态在Java 1.4及以下的版本中,每个线程都具有新建、可运行、阻塞、死亡四种状态,但是在Java 5.0及以上版本中,线程的状态被扩充为新建、可运行、阻塞、等待、定时等待、死亡六种。
线程的状态完全包含了一个线程从新建到运行,最后到结束的整个生命周期。
线程状态的具体信息如下:1. NEW(新建状态、初始化状态):线程对象已经被创建,但是还没有被启动时的状态。
这段时间就是在我们调用new命令之后,调用start()方法之前。
2. RUNNABLE(可运行状态、就绪状态):在我们调用了线程的start()方法之后线程所处的状态。
处于RUNNABLE状态的线程在JAVA虚拟机(JVM)上是运行着的,但是它可能还正在等待操作系统分配给它相应的运行资源以得以运行。
3. BLOCKED(阻塞状态、被中断运行):线程正在等待其它的线程释放同步锁,以进入一个同步块或者同步方法继续运行;或者它已经进入了某个同步块或同步方法,在运行的过程中它调用了某个对象继承自ng.Object的wait()方法,正在等待重新返回这个同步块或同步方法。
4. WAITING(等待状态):当前线程调用了ng.Object.wait()、ng.Thread.join()或者java.util.concurrent.locks.LockSupport.park()三个中的任意一个方法,正在等待另外一个线程执行某个操作。
比如一个线程调用了某个对象的wait()方法,正在等待其它线程调用这个对象的notify()或者notifyAll()(这两个方法同样是继承自Object类)方法来唤醒它;或者一个线程调用了另一个线程的join()(这个方法属于Thread类)方法,正在等待这个方法运行结束。
5. TIMED_WAITING(定时等待状态):当前线程调用了ng.Object.wait(long timeout)、ng.Thread.join(long millis)、java.util.concurrent.locks.LockSupport.packNanos(longnanos)、java.util.concurrent.locks.LockSupport.packUntil(longdeadline)四个方法中的任意一个,进入等待状态,但是与WAITING状态不同的是,它有一个最大等待时间,即使等待的条件仍然没有满足,只要到了这个时间它就会自动醒来。
6. TERMINATED(死亡状态、终止状态):线程完成执行后的状态。
线程执行完run()方法中的全部代码,从该方法中退出,进入TERMINATED状态。
还有一种情况是run()在运行过程中抛出了一个异常,而这个异常没有被程序捕获,导致这个线程异常终止进入TERMINATED状态。
在Java5.0及以上版本中,线程的全部六种状态都以枚举类型的形式定义在ng.Thread类中了,代码如下:public enum State {NEW,RUNNABLE,BLOCKED,WAITING,TIMED_WAITING,TERMINATED;}sleep()和wait()的区别sleep()方法和wait()方法都成产生让当前运行的线程停止运行的效果,这是它们的共同点。
下面我们来详细说说它们的不同之处。
sleep()方法是本地方法,属于Thread类,它有两种定义:public static native void sleep(long millis) throws InterruptedException;public static void sleep(long millis, int nanos) throws InterruptedException {//other code}其中的参数millis代表毫秒数(千分之一秒),nanos代表纳秒数(十亿分之一秒)。
这两个方法都可以让调用它的线程沉睡(停止运行)指定的时间,到了这个时间,线程就会自动醒来,变为可运行状态(RUNNABLE),但这并不表示它马上就会被运行,因为线程调度机制恢复线程的运行也需要时间。
调用sleep()方法并不会让线程释放它所持有的同步锁;而且在这期间它也不会阻碍其它线程的运行。
上面的连个方法都声明抛出一个InterruptedException类型的异常,这是因为线程在sleep()期间,有可能被持有它的引用的其它线程调用它的interrupt()方法而中断。
中断一个线程会导致一个InterruptedException异常的产生,如果你的程序不捕获这个异常,线程就会异常终止,进入TERMINATED状态,如果你的程序捕获了这个异常,那么程序就会继续执行catch语句块(可能还有finally语句块)以及以后的代码。
为了更好地理解interrupt()效果,我们来看一下下面这个例子:public class InterruptTest {public static void main(String[] args) {Thread t = new Thread() {public void run() {try {System.out.println("我被执行了-在sleep()方法前");// 停止运行10分钟Thread.sleep(1000 * 60 * 60 * 10);System.out.println("我被执行了-在sleep()方法后");} catch (InterruptedException e) {System.out.println("我被执行了-在catch语句块中");}System.out.println("我被执行了-在try{}语句块后");}};// 启动线程t.start();// 在sleep()结束前中断它t.interrupt();}}运行结果:1. 我被执行了-在sleep()方法前2. 我被执行了-在catch语句块中3. 我被执行了-在try{}语句块后wait()方法也是本地方法,属于Object类,有三个定义:public final void wait() throws InterruptedException {//do something}public final native void wait(long timeout) throws InterruptedException; public final void wait(long timeout, int nanos) throws InterruptedException {//do something}wari()和wait(long timeout,int nanos)方法都是基于wait(long timeout)方法实现的。