Toggle navigation
KANG's BLOG
Home
JAVA
MYSQL
KANG's BLOG
Let's have some fun
Java中的多线程
1. 线程状态 初始(NEW):新创建了一个线程对象,但还没有调用start()方法。 RUNNABLE):Java线程中将就绪(ready)和运行中(running)两种状态笼统的成为“运行”。 线程对象创建后,其他线程(比如main线程)调用了该对象的start()方法。该状态的线程位于可运行线程池中,等待被线程调度选中,获取cpu 的使用权,此时处于就绪状态(ready)。就绪状态的线程在获得cpu 时间片后变为运行中状态(running)。 阻塞(BLOCKED):表线程阻塞于锁。 等待(WAITING):进入该状态的线程需要等待其他线程做出一些特定动作(通知或中断)。 超时等待(TIME_WAITING):该状态不同于WAITING,它可以在指定的时间内自行返回。 终止(TERMINATED):表示该线程已经执行完毕。 2.
Posted by KANG's BLOG Tuesday, March 15, 2022
Java线程池原理
一、线城池处理任务的优先级 如果此时线程池中的数量小于corePoolSize,即使线程池中的线程都处于空闲状态,也要创建新的线程来处理被添加的任务。 如果此时线程池中的数量等于corePoolSize,但是缓冲队列 workQueue未满,那么任务被放入缓冲队列。 如果此时线程池中的数量大于corePoolSize,缓冲队列workQueue满,并且线程池中的数量小于maximumPoolSize,建新的线程来处理被添加的任务。 如果此时线程池中的数量大于corePoolSize,缓冲队列workQueue满,并且线程池中的数量等于maximumPoolSize,那么通过 handler所指定的策略来处理此任务。 核心线程corePoolSize、任务队列workQueue、最大线程maximumPoolSize,如果三者都满了,使用handler处理被拒绝的任务。 二、Handler拒绝策略 ThreadPoolExecutor.AbortPolicy() 抛出java.
Posted by KANG's BLOG Tuesday, March 15, 2022
FEATURED TAGS
database
distributed
http
java
jvm
lock
mq
mysql
nginx
ratelimiter
redis
tomcat
zookeeper
事务
多线程
架构
设计模式