JAVA多线程

1、并发、并行、串行的理解:
并行:多个线程各运行各的指令,不涉及抢占共同资源;
并发:多个线程运行时会抢占共同的资源;
串行:线程基于cpu来说都是串行的,cpu运行完这个线程的时间片就会调度另一个线程。

2、线程三大特性:
原子性:某个指令集要么全部运行完,要么全都不运行,不存在运行一半被调度出去的情况。
可见性:线程修改了内存之后,其他线程是可以感知到内存发生改变。JAVA可以使用volatile修饰属性保证可见性和防止指令重排。
有序性:指令按照程序员逻辑顺序执行,不可发生指令重排。

3、线程安全的理解:
并发情况下,多个线程会操作同一块临界区(同一内存块),由于一些指令的执行并非原子性,在执行一半时被调度出去,导致数据不一致产生内存的不安全。

4、Thread和Runable:
Runbale为接口,Thread是Runable的实现类,调用Thread的start方法会新创建一个虚拟机栈(新的线程)来执行run方法。
new Thread时可以传入实现Runable的实例,线程可以针对不同的实现了Runable的实例运行不同的逻辑代码。

5、TheadLocal:
Threadlocal将数据作用域局限在当前线程,不被其他线程共享,实现数据安全,ThreadLocal使用内部的ThreadLocalMap保存数据,记得释放不需要的数据,防止内存泄露(其实map或者collection都需要将不需要的数据释放,防止内存泄露)。

6、线程的状态都有哪些:
NEW(new Thread())、RUNABLE(等待系统调度)、RUNNING(CPU正在运行)、BLOCKED(IO、网络、wait()、park()、sleep()、竞争不到锁)、DEAD(执行完毕、发生错误)

7、线程池怎么做到线程复用:
线程池中的Thread调用传进来的任务的run方法,执行完run方法之后循环等待新的任务进来。

8、线程池的执行流程:
提交任务之后,线程数是否不超过corePoolSize,不超过的话调度空闲线程或新建核心线程执行任务;核心线程数超过corePoolSize,判断阻塞队列是否已满,未满的话加入队列等待核心线程空闲出来执行任务,队列已满,判断线程数是否超出maximumPoolSize,未超出新建队列执行任务,超出最大线程数,执行拒绝策略。

9、线程池的参数有哪些:
corePoolSize:核心线程数,线程池常驻的线程数量;
maxinumPoolSize:最大核心线程数,任务非常多时,线程池的线程数量不得超出这个值;
BlockingQueue:阻塞队列,当线程数达到corePoolSize时,进来的任务会加入阻塞队列中,阻塞队列满时新建线程(总线程数不得超出maxinumPoolSize)执行任务。
keepTimeLive:非核心线程数空闲时存活时间。

10、sleep()、wait()、yield()、join():
sleep()是Thread的静态方法,调用其当前线程会进入阻塞状态直至sleep时间结束,如果获得锁,并不会释放锁;
wait()是object的方法,调用其会释放锁,等待notify()或者notifyAll()唤醒;
yield()让出cpu执行,状态由RUNNING转为RUNABLE;
join()当前线程等待join方法的Thread实例运行结束。

11、为什么线程数超出核心线程数时,线程池要先将任务放到阻塞队列:
尽可能减少超出核心线程数时创建新的线程,减少线程创建的开销和太多线程调度开销。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值