AQS使用一个int成员变量来表示同步状态,通过内置的FIFO队列来完成获取资源线程的排队工作。AQS使用CAS对该同步状态进行原子操作实现对其值的修改。
// 创建ThreadPoolExecutorpublic static ExecutorService newFixedThreadPool(int nThreads) {return new ThreadPoolExecutor(nThreads, nThreads,0L, TimeUnit.MILLISECONDS,new LinkedBlockingQueue);}// 指定默认的线程创建工厂和拒绝策略public ThreadPoolExecutor(int corePoolSize,int maximumPoolSize,long keepAliveTime,TimeUnit unit,BlockingQueue workQueue) {this(corePoolSize, maximumPoolSize, keepAliveTime, unit, workQueue,Executors.defaultThreadFactory, defaultHandler);}/ 使用给定的参数创建ThreadPoolExecutor.** @param corePoolSize 核心线程池中的最大线程数* @param maximumPoolSize 总线程池中的最大线程数* @param keepAliveTime 空闲线程的存活时间* @param unit keepAliveTime的单位* @param workQueue 任务队列, 保存已经提交但尚未被执行的线程* @param threadFactory 线程工厂(用于指定如何创建一个线程)* @param handler 拒绝策略 (当任务太多导致工作队列满时的处理策略)*/public ThreadPoolExecutor(int corePoolSize,int maximumPoolSize,long keepAliveTime,TimeUnit unit,BlockingQueue workQueue,ThreadFactory threadFactory,RejectedExecutionHandler handler) {if (corePoolSize < 0。
private volatile int state;//共享变量,使用volatile修饰保证线程可见性。
首先题目是中文的,比较友好。题目全,不仅包括了所有英文站的题目,还增加了《剑指Offer》等面试常考的题目。另外,讨论区的质量很高呀,很多大牛出没,而且讲解的更多面向初学者!活动组织的比较多,比如最近的每日一题活动。发布于 2020-03-29赞同 10添加评论收藏喜欢收起继续浏览内容知乎发现更大的世界打开浏览器继续匿名用户15 人赞同了该回答我个人觉得牛客网会更好一些,毕竟LeetCode中文产品刚出来没多久,体验还是功能都需要打磨,不如牛客网更成熟。
leetcode题目多,类型全面,最重要的是检查严格,有的代码牛客能过,leetcode过不了,有bad case。