口碑好的丹徒网站建设哪个网站找做软件下载

web/2025/9/27 3:02:46/文章来源:
口碑好的丹徒网站建设,哪个网站找做软件下载,常见的网络营销推广方法有哪些,北京到邢台转载自 Java中的ThreadPoolExecutor类在前面的文章中#xff0c;我们使用线程的时候就去创建一个线程#xff0c;这样实现起来非常简便#xff0c;但是就会有一个问题#xff1a; 如果并发的线程数量很多#xff0c;并且每个线程都是执行一个时间很短的任务就结束了…转载自  Java中的ThreadPoolExecutor类在前面的文章中我们使用线程的时候就去创建一个线程这样实现起来非常简便但是就会有一个问题 如果并发的线程数量很多并且每个线程都是执行一个时间很短的任务就结束了这样频繁创建线程就会大大降低系统的效率因为频繁创建线程和销毁线程需要时间。 那么有没有一种办法使得线程可以复用就是执行完一个任务并不被销毁而是可以继续执行其他的任务 在Java中可以通过线程池来达到这样的效果。今天我们就来详细讲解一下Java的线程池首先我们从最核心的ThreadPoolExecutor类中的方法讲起然后再讲述它的实现原理接着给出了它的使用示例最后讨论了一下如何合理配置线程池的大小。 Java中的ThreadPoolExecutor类 java.uitl.concurrent.ThreadPoolExecutor类是线程池中最核心的一个类因此如果要透彻地了解Java中的线程池必须先了解这个类。下面我们来看一下ThreadPoolExecutor类的具体实现源码。 在ThreadPoolExecutor类中提供了四个构造方法 public class ThreadPoolExecutor extends AbstractExecutorService {public ThreadPoolExecutor(int corePoolSize,int maximumPoolSize,long keepAliveTime,TimeUnit unit,BlockingQueueRunnable workQueue);public ThreadPoolExecutor(int corePoolSize,int maximumPoolSize,long keepAliveTime,TimeUnit unit,BlockingQueueRunnable workQueue,ThreadFactory threadFactory);public ThreadPoolExecutor(int corePoolSize,int maximumPoolSize,long keepAliveTime,TimeUnit unit,BlockingQueueRunnable workQueue,RejectedExecutionHandler handler);public ThreadPoolExecutor(int corePoolSize,int maximumPoolSize,long keepAliveTime,TimeUnit unit,BlockingQueueRunnable workQueue,ThreadFactory threadFactory,RejectedExecutionHandler handler); } 从上面的代码可以得知ThreadPoolExecutor继承了AbstractExecutorService类并提供了四个构造器事实上通过观察每个构造器的源码具体实现发现前面三个构造器都是调用的第四个构造器进行的初始化工作。 下面解释下一下构造器中各个参数的含义 corePoolSize核心池的大小这个参数跟后面讲述的线程池的实现原理有非常大的关系。在创建了线程池后默认情况下线程池中并没有任何线程而是等待有任务到来才创建线程去执行任务除非调用了prestartAllCoreThreads()或者prestartCoreThread()方法从这2个方法的名字就可以看出是预创建线程的意思即在没有任务到来之前就创建corePoolSize个线程或者一个线程。默认情况下在创建了线程池后线程池中的线程数为0当有任务来之后就会创建一个线程去执行任务当线程池中的线程数目达到corePoolSize后就会把到达的任务放到缓存队列当中maximumPoolSize线程池最大线程数这个参数也是一个非常重要的参数它表示在线程池中最多能创建多少个线程keepAliveTime表示线程没有任务执行时最多保持多久时间会终止。默认情况下只有当线程池中的线程数大于corePoolSize时keepAliveTime才会起作用直到线程池中的线程数不大于corePoolSize即当线程池中的线程数大于corePoolSize时如果一个线程空闲的时间达到keepAliveTime则会终止直到线程池中的线程数不超过corePoolSize。但是如果调用了allowCoreThreadTimeOut(boolean)方法在线程池中的线程数不大于corePoolSize时keepAliveTime参数也会起作用直到线程池中的线程数为0unit参数keepAliveTime的时间单位有7种取值在TimeUnit类中有7种静态属性NANOSECONDS, //纳秒 MICROSECONDS, //微妙 MILLISECONDS, //毫秒 SECONDS, //秒 MINUTES, //分钟 HOURS, //小时 DAYS; //天workQueue一个阻塞队列用来存储等待执行的任务这个参数的选择也很重要会对线程池的运行过程产生重大影响一般来说这里的阻塞队列有以下几种选择ArrayBlockingQueue LinkedBlockingQueue; PriorityBlockingQueue; SynchronousQueue; ArrayBlockingQueue和PriorityBlockingQueue使用较少一般使用LinkedBlockingQueue和Synchronous。线程池的排队策略与BlockingQueue有关。 threadFactory线程工厂主要用来创建线程handler表示当拒绝处理任务时的策略有以下四种取值 ThreadPoolExecutor.AbortPolicy:丢弃任务并抛出RejectedExecutionException异常。 ThreadPoolExecutor.DiscardPolicy也是丢弃任务但是不抛出异常。 ThreadPoolExecutor.DiscardOldestPolicy丢弃队列最前面的任务然后重新尝试执行任务重复此过程ThreadPoolExecutor.CallerRunsPolicy由调用线程处理该任务具体参数的配置与线程池的关系将在下一节讲述。 从上面给出的ThreadPoolExecutor类的代码可以知道ThreadPoolExecutor继承了AbstractExecutorService我们来看一下AbstractExecutorService的实现 public abstract class AbstractExecutorService implements ExecutorService {protected T RunnableFutureT newTaskFor(Runnable runnable, T value) { }protected T RunnableFutureT newTaskFor(CallableT callable) { }public Future? submit(Runnable task) {}public T FutureT submit(Runnable task, T result) {}public T FutureT submit(CallableT task) {}private T T doInvokeAny(Collection? extends CallableT tasks, boolean timed, long nanos)throws InterruptedException, ExecutionException, TimeoutException {}public T T invokeAny(Collection? extends CallableT tasks) throws InterruptedException, ExecutionException {}public T T invokeAny(Collection? extends CallableT tasks, long timeout, TimeUnit unit)throws InterruptedException, ExecutionException, TimeoutException {}public T ListFutureT invokeAll(Collection? extends CallableT tasks) throws InterruptedException {}public T ListFutureT invokeAll(Collection? extends CallableT tasks, long timeout, TimeUnit unit)throws InterruptedException {} AbstractExecutorService是一个抽象类它实现了ExecutorService接口。 我们接着看ExecutorService接口的实现 public interface ExecutorService extends Executor {void shutdown();ListRunnable shutdownNow();boolean isShutdown();boolean isTerminated();boolean awaitTermination(long timeout, TimeUnit unit)throws InterruptedException;T FutureT submit(CallableT task);T FutureT submit(Runnable task, T result);Future? submit(Runnable task);T ListFutureT invokeAll(Collection? extends CallableT tasks)throws InterruptedException;T ListFutureT invokeAll(Collection? extends CallableT tasks,long timeout, TimeUnit unit)throws InterruptedException;T T invokeAny(Collection? extends CallableT tasks)throws InterruptedException, ExecutionException;T T invokeAny(Collection? extends CallableT tasks,long timeout, TimeUnit unit) throwsInterruptedException, ExecutionException, TimeoutException; } 而ExecutorService又是继承了Executor接口我们看一下Executor接口的实现 public interface Executor {void execute(Runnable command); } 到这里大家应该明白了ThreadPoolExecutor、AbstractExecutorService、ExecutorService和Executor几个之间的关系了。 Executor是一个顶层接口在它里面只声明了一个方法execute(Runnable)返回值为void参数为Runnable类型从字面意思可以理解就是用来执行传进去的任务的 然后ExecutorService接口继承了Executor接口并声明了一些方法submit、invokeAll、invokeAny以及shutDown等 抽象类AbstractExecutorService实现了ExecutorService接口基本实现了ExecutorService中声明的所有方法 然后ThreadPoolExecutor继承了类AbstractExecutorService。 在ThreadPoolExecutor类中有几个非常重要的方法 execute()submit()shutdown()shutdownNow()execute()方法实际上是Executor中声明的方法在ThreadPoolExecutor进行了具体的实现这个方法是ThreadPoolExecutor的核心方法通过这个方法可以向线程池提交一个任务交由线程池去执行。 submit()方法是在ExecutorService中声明的方法在AbstractExecutorService就已经有了具体的实现在ThreadPoolExecutor中并没有对其进行重写这个方法也是用来向线程池提交任务的但是它和execute()方法不同它能够返回任务执行的结果去看submit()方法的实现会发现它实际上还是调用的execute()方法只不过它利用了Future来获取任务执行结果Future相关内容将在下一篇讲述。 shutdown()和shutdownNow()是用来关闭线程池的。 还有很多其他的方法 比如getQueue() 、getPoolSize() 、getActiveCount()、getCompletedTaskCount()等获取与线程池相关属性的方法有兴趣的朋友可以自行查阅API。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/82505.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

网站建设与管理教学视频下载手机网站如何制作免费

1.微服务架构模式方案 用Scale Cube方法设计应用架构,将应用服务按功能拆分成一组相互协作的服务。每个服务负责一组特定、相关的功能。每个服务可以有自己独立的数据库,从而保证与其他服务解耦。 1.1 聚合器微服务设计模式 聚合器调用多个服务实现应用程…

网站托管服务商长春880元网站建设

现在距离2024年第11届汉字小达人比赛还有六个多月的时间,如何利用这段时间有条不紊地备考呢?我的建议是两手准备:①把小学1-5年级的语文课本上的知识点熟悉,重点是字、词、成语、古诗。阅读理解不需要。②把历年真题刷刷熟&#x…

建站行业发展酷家乐个人免费版官网

1.背包问题 (1)01背包 从n个重量和价值分别为wi,vi的物品,从中选出不超过W的物品,每种物品仅有一件,求所有方案中V的最大值。 最朴素最简单也最费时的方法:O(2^n) int rec(int i,int j)//从第i个开始挑选总…

网站文字设计食品公司网站源码

这里写目录标题 C基础语法变量与运算条件判断循环结构 数组和字符串一维数组二维数组字符串处理 函数与算法函数定义常用算法 数据结构链表与顺序表栈和队列树 计算机基础硬件组成数据单位进制转换 C知识点总结,适合六年级刚学C的学生: C基础语法 变量与…

孝感做网站网站运营包括哪些

点开“虚拟机->设置->桥接模式(勾选复制物理网络连接状态)->确认” 点击“右上角扇形网络图标->Edit Connections->Wired->选中->Delete->Add->IPv4 Settings->Method(Manual)->Add->输入IP,子网掩码&am…

在哪个平台做网站好网页设计指什么

【写在前面】 飞腾开发者平台是基于飞腾自身强大的技术基础和开放能力,聚合行业内优秀资源而打造的。该平台覆盖了操作系统、算法、数据库、安全、平台工具、虚拟化、存储、网络、固件等多个前沿技术领域,包含了应用使能套件、软件仓库、软件支持、软件适…

互联网电商网站建设wordpress 百度搜索

数据表信息查看 1、维度查看: df.shape2、数据表基本信息(维度、列名称、数据格式、所占空间等): df.info()3、每一列数据的格式: df.dtypes4、某一列格式: df[B].dtype5、空值: df.isnul…

全国建设地产网站做网站注册商标

Runway Gen-2的官方网站提供了一种文本生成视频的工具。以下是对该工具的介绍: 文本生成视频:Runway Gen-2是一个创新的在线工具,可以将文本转化为视频。用户只需输入文本描述或句子,Runway Gen-2就能自动生成相应的视频内容。这…

网站被镜像怎么办宝应县天宇建设网站

一、为什么使用严格模式? 在普通的 JavaScript 中,写错变量名会创建新的全局变量, 在严格模式中,写错变量名会抛出错误来提醒开发者 二、声明严格模式 通过在脚本或函数的开头添加 “use strict”; 来声明严格模式。"use …

建立网站的文案怎么写西安金融网站建设

如果ifconfig只显示了lo, ifconfig -a 却正常显示ens33。那么可以按照如下的操作: service network-manager stop rm /var/lib/NetworkManager/NetworkManager.state service network-manager start 即可恢复网络连接

网站建设中怎么编辑图片做网站php与python

​ 本周安全态势综述 OSCS 社区共收录安全漏洞 3 个,公开漏洞值得关注的是 VMware Aria Operations SSH 身份验证绕过漏洞( CVE-2023-34039 )、Apache Airflow Spark Provider 反序列化漏洞( CVE-2023-40195 )。 针对 NPM 仓库,共监测到 324 个不同版本…

工程设计东莞网站建设技术支持网站的统计 怎么做

目录 前言初始化数据库Docker 部署 xxl-job下载镜像创建容器并运行访问调度中心 SpringBoot 整合 xxl-jobpom.xmlapplication.ymlXxlJobConfig.java执行器注册查看 定时任务测试添加测试任务配置定时任务测试结果 结语附录xxl-job 官方文档xxl-job 源码测试项目源码 前言 xxl-…

网站空间1深圳龙岗设计

n 皇后问题 研究的是如何将 n 个皇后放置在 n n 的棋盘上,并且使皇后彼此之间不能相互攻击。 给你一个整数 n ,返回 n 皇后问题 不同的解决方案的数量。 示例 1: 输入:n 4 输出:2 解释:如上图所示&…

住建局网站信息化建设如何查公司的工商注册信息

C# ComboBox 和 枚举类型(Enum)相互关联 目的 在C# Winform面板上的ComboBox选择项,由程序填写某个Enum的各个枚举项目。 在运行中读取ComboBox的选择项,返回Enum数值。 非编程方法 低阶做法可以在winform设计窗口手动填写,但是不会自动跟…

怎么建设一个电影资源网站解析经典软文案例100例

看文献过程中不断发现有太多不懂的基础知识,故长期更新这类blog不断补充在这过程中学到的知识。由于这些内容与我的研究方向并不一定强相关,故记录不会很深入请见谅。 【通信基础知识补充7】25年2月通信基础知识补充1 一、多普勒频移与多普勒扩展傻傻分不…

戒赌网站怎么做九台网络推广

PostgreSQL 数据库源码编译安装全流程详解 Linux 8 1. 基础环境配置1.1 修改主机名1.2 配置操作系统yum源1.3 安装操作系统依赖包1.4 禁用SELINUX配置1.5 关闭操作系统防火墙1.6 创建用户和组1.7 建立安装目录1.8 编辑环境变量 2. 源码方式安装(PG 16)2.…

网站建设佰金手指科杰十八山东省建设银行网站

一、CAS概念和应用背景 CAS的作用和用途 CAS(Compare and Swap)是一种并发编程中常用的技术,用于解决多线程环境下的并发访问问题。CAS操作是一种原子操作,它可以提供线程安全性,避免了使用传统锁机制所带来的性能开…

品牌网站设计地址移动互联网开发学习心得

目录硬知识概念I/O口配置准双向口/弱上拉输出配置开漏输出配置实战延时函数的生成闪烁一个LED灯源码实验现象流水灯源码实验现象按键控制LED灯按键介绍源码实验现象普中51-单核-A2 STC89C52 Keil uVision V5.29.0.0 PK51 Prof.Developers Kit Version:9.60.0.0 硬知识 概念 …

做一个网站要多长时间微网站开发微网站建设

简介 在嵌入式开发中,经常有需要用到RingBuffer的概念,在RingBuffer中经常遇到一个Buffer满和Buffer空的判断的问题,一般的做法是留一个单位的buffer不用,这样做最省事,但是当RingBuffer单位是一个结构体时&#xff0…

校园网站建设总结石家庄商城网站建设

Windows MySQL服务安装及问题解决方案 安装及配置步骤一:官网下网MySQL安装包步骤二:设置环境变量步骤仨:配置MySQL,ini配置文件步骤四:初始化MySQL步骤五:开启MySQL服务步骤六:测试是否安装成功步骤七&…