Python 官方文档:入门教程 => 点击学习
目录1、在启动线程时,为什么要通过调用方法start执行方法run,而不能直接执行方法run?2、方法sleep、join和yield的区别有哪些?3.为什么方法wait、notif
调用方法start执行方法run,才是多线程的工作,**如果直接执行方法run,会被当成一个主线程下的普通方法执行,**而不会在某个线程中执行,因此不是多线程工作。
方法sleep的作用是使当前线程暂停执行一段时间,让其他线程有机会继续执行;
方法join的作用是阻塞调用该方法的线程,直到当前线程执行完毕后,调用该方法的线程才能继续执行;
方法yield的作用是暂停当前正在执行的线程对象,并执行其他线程。
其中主要的原因是:
方法 wait、notify 和 notifyAll 不只是普通方法或同步工具,它们还是 Java 中两个线程之间的通信机制。对语言设计者而言, 如果不能通过 Java 关键字(例如 synchronized)实现通信机制,同时又要确保这个机制对每个对象可用,那么 Object 类则是的合理的声明位置。每个对象都可上锁,因此方法 wait 和 notify 在 Object 类而不是 Thread 类定义。
终止线程应该使用方法interrupt,使用方法stop会带来两个问题,
一是清理性工作无法完成;
二是会立即释放所有锁,导致对象状态不一致。因此会造成不安全。
而方法destroy除了抛出NoSuchMethodError 以外没有做任何事情,因此无法终止线程。
线程池是一种线程的使用模式,创建若干个可执行的线程放入一个池(容器)中,有任务需要处理时,会提交到线程池中的任务队列,处理完后线程并不会被销毁,而是仍然在线程池中等待下一个任务。
使用线程池有以下三点好处:
线程池的创建可以通过ThreadPoolExecutor类,
ThreadPoolExecutor类有4个构造方法,其中最一般话的构造方法包含7个参数。
public ThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue<Runnable> workQueue, ThreadFactory threadFactory, RejectedExecutionHandler handler)
这7个参数的含义分别是:
corePoolSize
: 核心线程数,定义了最少可以同时运行的线程数量,当有新的任务时就会创建一个线程执行任务,当线程池中的线程数量达到corePoolSize 之后,到达的任务进入阻塞队列maximumPoolSize
: 最大线程数,定义了线程池中最多能创建的线程数量。keepAliveTime
: 等待时间,当线程池中的线程数量大于 corePoolSize 时,如果一个线程的空闲时间达到keepAliveTime 时则会终止,直到线程池中的线程数不超过 corePoolSize。unit
: 参数keepAliveTime 的单位。workQueue
: 阻塞队列,用来存储等待执行的任务。threadFactory
: 创建线程的工厂。handler
: 当拒绝处理任务时的策略。核心线程和非核心线程的最大数目在创建线程时被锁定,核心线程和非核心线程的区别如下:
可以通过调用线程池的方法shutdown或shutdownNow关闭线程池,
这两个方法的原理是 遍历线程池中的工作线程,对每个工作线程调用 interrupt 方法中断线程,无法响应中断的任务可能永远无法终止。
方法 shutDown 和 shutDownNow 有以下区别。
方法 shutDown 将线程池的状态设置成 SHUTDOWN,正在执行的任务继续执行,没有执行的任务将中断。
方法 shutDownNow 将线程池的状态设置成 STOP,正在执行的任务被停止,没有执行的任务被返回。
多线程以及线程池相关的面试其实主要就是考察是否真正的使用过多线程和线程池开发,所以主要就是掌握多线程和线程池的创建和销毁方法、了解线程池的原理。重点在于实践。
本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注编程网的更多内容!
--结束END--
本文标题: Java线程池高频面试题总结
本文链接: https://lsjlt.com/news/132411.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-03-01
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0