标签:cimage 含义 线程 今天 OLE over queue 主线程 main方法
大家好,我是Java最全面试题库
的提裤姐
,今天这篇是JavaSE
系列的第十一篇,主要总结了Java中的多线程
问题,多线程分为三篇来讲,这篇是第一篇,在后续,会沿着第一篇开篇的知识线路一直总结下去,做到日更!如果我能做到百日百更,希望你也可以跟着百日百刷,一百天养成一个好习惯。
进程:
具有一定独立功能的程序关于某个数据集合上的一次运行活动,是操作系统进行资源分配和调度的一个独立单位。
线程:
是进程的一个实体,是 cpu 调度和分派的基本单位,是比进程更小的可以独立运行的基本单位。
特点:
注意:多线程编程对于其它程序是不友好的,占据大量 cpu 资源。
两个:
主线程
:负责main方法代码的执行,垃圾回收器线程
:负责了回收垃圾。sleep()方法:
Thread类中的静态方法
,
当一个线程调用sleep()方法以后,不会释放
同步资源锁,其他线程仍然会等待资源锁的释放。
wait()方法:
Object类提供的一个普通方法
,
而且必须同同步资源锁对象在同步代码块或者同步方法中调用。
当调用wait()方法后,当前线程会立刻释放
掉同步锁资源。其他线程就有机会获得同步资源锁从而继续往下执行。
方式一:继承Thread类创建线程类
class T extends Thread{
@Override
public void run() {
}
}
方式二:通过Runnable接口创建线程类
class T implements Runnable{
@Override
public void run() {
}
}
方式三:通过Callable和Future创建线程
class T implements Callable<String> {
@Override
public String call() throws Exception {
return null;
}
}
线程池可以提高线程的创建和销毁的开销
jdk提供了以下几种线程池:
一般工作中使用的是new ThreadPoolExecutor
ThreadPoolExecutor(
int corePoolSize, //核心线程池大小
int maximumPoolSize, //最大线程池大小
long keepAliveTime, //线程最大空闲时间
TimeUnit unit, //时间单位
BlockingQueue<Runnable> workQueue, //线程等待队列
ThreadFactory threadFactory, //线程创建工厂
RejectedExecutionHandler handler //拒绝策略
) {
新建状态(New)
:就绪状态(Runnable)
:运行状态(Running)
:阻塞状态(Blocked)
:死亡状态(Dead)
:注意:就绪状态是进入到运行状态的唯一入口,也就是说,线程要想进入运行状态执行,首先必须处于就绪状态中;
标签:cimage 含义 线程 今天 OLE over queue 主线程 main方法
原文地址:https://www.cnblogs.com/hongcaixia/p/13282977.html