Java高级技术-多线程

Java高级面试-多线程

一、多线程创建

1.thread/runnable

1)继承Thread

 

 

2)实现Runnable接口

 

 

 

2.两种启动线程方法的区别

Thread类实现了Runable接口。

都需要重写里面Run方法。

 

区别

实现Runnable的类更具有健壮性,避免了单继承的局限。

Runnable更容易实现资源共享,能多个线程同时处理一个资源。

 

3.star方法和run方法的区别

区别:调用start方法实现多线程,而调用run方法没有实现多线程

Start:

start方法来启动线程,真正实现了多线程运行,这时无需等待run方法体代码执行完毕而直接继续执行下面的代码。通过调用Thread类的start()方法来启动一个线程,这时此线程处于就绪(可运行)状态,并没有运行,一旦得到spu时间片,就开始执行run()方法,这里方法run()称为线程体,它包含了要执行的这个线程的内容,Run方法运行结束,此线程随即终止。

Run:

run()方法只是类的一个普通方法而已,如果直接调用Run方法,程序中依然只有主线程这一个线程,其程序执行路径还是只有一条,还是要顺序执行,还是要等待run方法体执行完毕后才可继续执行下面的代码,这样就没有达到写线程的目的。

总结:调用start方法方可启动线程,而run方法只是thread的一个普通方法调用,还是在主线程里执行。

 

二、线程间通信

1.synchronized关键字

1)synchronized对象锁

 

2)synchronized来实现线程间通信

不同线程去共享同一个变量来进行锁的管理

3)synchronized/volatile

使用volatile声明的变量,只能从主内存中获取,不复制到线程中,当该变量改变后,所有线程中该变量都发生改变

4)synchronized/lock

悲观锁、乐观锁

 

2.sleep/wait

 

3.wait/notify机制

 

 

三、线程池

 

1.好处

1)降低资源消耗

2)提高响应速度

3)提高线程的可管理性

 

2.ThreadPoolExecutor

new ThreadPoolExecutor(corePoolSize,maximumPoolSize,

keepAliveTime,milliseconds,runnableTaskQueue,handler);

 

创建线程池->提交任务

 

3.线程池的工作流程

 

1)首先线程池判断基本线程池是否已满

2)其次线程池判断工作队列是否已满

3)最后线程池判断整个线程池是否已满

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值