- 浏览: 369237 次
- 性别:
- 来自: 四川
文章分类
- 全部博客 (247)
- 数据库以及sql (11)
- java (48)
- 爬虫学习 (20)
- java编程 (28)
- python编程以及安装和配置 (27)
- oracle数据库 (32)
- mongodb基本操作 (4)
- linux学习 (7)
- easyUI (2)
- nodeJs (8)
- python学习 (16)
- 其他 (13)
- hadoop (1)
- svn (1)
- 汉字 (1)
- windows (2)
- jsp (5)
- fiddler (1)
- ETL (1)
- teamviewer (1)
- maven (4)
- GIT (2)
- datagrip (1)
- ocr (1)
- redis (3)
- mysql (3)
- linux (1)
- 数据服务 (0)
最新评论
Java通过Executors提供四种线程池:
1.newCachedThreadPool: 创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。
2.newFixedThreadPool: 创建一个定长线程池,可控制线程最大并发数,超出的线程会在队列中等待。
3.newScheduledThreadPool: 创建一个定长线程池,支持定时及周期性任务执行。
4.newSingleThreadExecutor: 创建一个单线程化的线程池,它只会用唯一的工作线程来执行任务,保证所有任务按照指定顺序(FIFO, LIFO, 优先级)执行。
1.
package com.teamdev.jxbrowser.chromium.demo.线程池;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class cachedThreadPoolTest {
/**
* @remark 创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。线程池中有线程够用,我们就不会新建线程,若不够,就会新建。
* 线程池为无限大,当执行第二个任务时第一个任务已经完成,会复用执行第一个任务的线程,而不用每次新建线程。
* */
public static void main(String[] args) {
//创建一个缓冲线程池
ExecutorService newCachedThread= Executors.newCachedThreadPool();
for (int i = 0; i < 20; i++) {
final int index=i;
try {
Thread.sleep(1000*index);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
newCachedThread.execute(new Runnable(){
public void run() {
// TODO Auto-generated method stub
System.out.println(Thread.currentThread().getName()+" output:"+index);
}
});
}
}
}
2.
package com.teamdev.jxbrowser.chromium.demo.线程池;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class fixedThreadPoolTest {
/**
* @remark 本人理解,每隔两秒创建五个线程,控制线程并发数.
* 定长线程池的大小最好根据系统资源进行设置
* */
public static void main(String[] args) {
//创建一个定长线程池,可控制线程最大并发数,超出的线程会在队列中等待。示例代码如下:
ExecutorService fixedThreadPool = Executors.newFixedThreadPool(4);
for (int i = 1; i <= 20; i++) {
final int index = i;
fixedThreadPool.execute(new Runnable() {
public void run() {
try {
//System.out.println(index);
System.out.println(Thread.currentThread().getName()+" output:"+index);
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
});
}
}
}
3.
package com.teamdev.jxbrowser.chromium.demo.线程池;
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;
public class scheduledThreadPoolTest {
/**
* @remark 创建一个定长线程池,支持定时及周期性任务执行
* */
public static void main(String[] args) {
// ScheduledExecutorService scheduledThreadPool = Executors.newScheduledThreadPool(5);
// scheduledThreadPool.schedule(new Runnable() {
// public void run() {
// // TODO Auto-generated method stub
// System.out.println(Thread.currentThread().getName());
// }
// },5,TimeUnit.SECONDS);//表示延迟5秒执行,只执行一次,并没有周期执行。
ScheduledExecutorService scheduledThreadPool = Executors.newScheduledThreadPool(5);
scheduledThreadPool.scheduleAtFixedRate(new Runnable() {
public void run() {
System.out.println(Thread.currentThread().getName() +"-3s/次");
}
}, 1, 3, TimeUnit.SECONDS);//每隔3秒执行,周期性
}
}
4.
package com.teamdev.jxbrowser.chromium.demo.线程池;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class SingleThreadExecutorPoolTest {
/**
* @remark 创建一个单线程化的线程池,它只会用唯一的工作线程来执行任务,
* 保证所有任务按照指定顺序(FIFO, LIFO, 优先级)执行。
* */
public static void main(String[] args) {
ExecutorService singleThreadExecutor = Executors.newSingleThreadExecutor();
for (int i = 0; i<100; i++) {
final int index = i;
singleThreadExecutor.execute(new Runnable() {
public void run() {
try {
System.out.println(Thread.currentThread().getName() +" output:"+index);
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
});
}
}
//你可以使用JDK自带的监控工具来监控我们创建的线程数量来观察:运行线程后
//工具目录:c:\...\jdk\bin\jconsole.exe, 打开
//本地进程下 选择 该在运行的线程路径,双击 进去 观察即可(可能会弹出不安全的警告,点击不安全即可)
}
1.newCachedThreadPool: 创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。
2.newFixedThreadPool: 创建一个定长线程池,可控制线程最大并发数,超出的线程会在队列中等待。
3.newScheduledThreadPool: 创建一个定长线程池,支持定时及周期性任务执行。
4.newSingleThreadExecutor: 创建一个单线程化的线程池,它只会用唯一的工作线程来执行任务,保证所有任务按照指定顺序(FIFO, LIFO, 优先级)执行。
1.
package com.teamdev.jxbrowser.chromium.demo.线程池;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class cachedThreadPoolTest {
/**
* @remark 创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。线程池中有线程够用,我们就不会新建线程,若不够,就会新建。
* 线程池为无限大,当执行第二个任务时第一个任务已经完成,会复用执行第一个任务的线程,而不用每次新建线程。
* */
public static void main(String[] args) {
//创建一个缓冲线程池
ExecutorService newCachedThread= Executors.newCachedThreadPool();
for (int i = 0; i < 20; i++) {
final int index=i;
try {
Thread.sleep(1000*index);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
newCachedThread.execute(new Runnable(){
public void run() {
// TODO Auto-generated method stub
System.out.println(Thread.currentThread().getName()+" output:"+index);
}
});
}
}
}
2.
package com.teamdev.jxbrowser.chromium.demo.线程池;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class fixedThreadPoolTest {
/**
* @remark 本人理解,每隔两秒创建五个线程,控制线程并发数.
* 定长线程池的大小最好根据系统资源进行设置
* */
public static void main(String[] args) {
//创建一个定长线程池,可控制线程最大并发数,超出的线程会在队列中等待。示例代码如下:
ExecutorService fixedThreadPool = Executors.newFixedThreadPool(4);
for (int i = 1; i <= 20; i++) {
final int index = i;
fixedThreadPool.execute(new Runnable() {
public void run() {
try {
//System.out.println(index);
System.out.println(Thread.currentThread().getName()+" output:"+index);
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
});
}
}
}
3.
package com.teamdev.jxbrowser.chromium.demo.线程池;
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;
public class scheduledThreadPoolTest {
/**
* @remark 创建一个定长线程池,支持定时及周期性任务执行
* */
public static void main(String[] args) {
// ScheduledExecutorService scheduledThreadPool = Executors.newScheduledThreadPool(5);
// scheduledThreadPool.schedule(new Runnable() {
// public void run() {
// // TODO Auto-generated method stub
// System.out.println(Thread.currentThread().getName());
// }
// },5,TimeUnit.SECONDS);//表示延迟5秒执行,只执行一次,并没有周期执行。
ScheduledExecutorService scheduledThreadPool = Executors.newScheduledThreadPool(5);
scheduledThreadPool.scheduleAtFixedRate(new Runnable() {
public void run() {
System.out.println(Thread.currentThread().getName() +"-3s/次");
}
}, 1, 3, TimeUnit.SECONDS);//每隔3秒执行,周期性
}
}
4.
package com.teamdev.jxbrowser.chromium.demo.线程池;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class SingleThreadExecutorPoolTest {
/**
* @remark 创建一个单线程化的线程池,它只会用唯一的工作线程来执行任务,
* 保证所有任务按照指定顺序(FIFO, LIFO, 优先级)执行。
* */
public static void main(String[] args) {
ExecutorService singleThreadExecutor = Executors.newSingleThreadExecutor();
for (int i = 0; i<100; i++) {
final int index = i;
singleThreadExecutor.execute(new Runnable() {
public void run() {
try {
System.out.println(Thread.currentThread().getName() +" output:"+index);
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
});
}
}
//你可以使用JDK自带的监控工具来监控我们创建的线程数量来观察:运行线程后
//工具目录:c:\...\jdk\bin\jconsole.exe, 打开
//本地进程下 选择 该在运行的线程路径,双击 进去 观察即可(可能会弹出不安全的警告,点击不安全即可)
}
发表评论
-
是什么java多态
2018-11-14 13:43 611Java多态 例1.1+1=2 例2."1&quo ... -
经纬度转换
2018-09-25 13:57 0package com.teamdev.jxbrowser.c ... -
java连接池技术
2018-09-04 14:26 339转:https://www.cnblogs.com/xdp-g ... -
java 提取url字符串中的域名
2018-08-30 15:24 7326package com.teamdev.jxbrowser.c ... -
java多线程中锁(lock)、wait、notify()的使用
2018-07-13 11:31 5688package com.kai.多线程间的通信; impor ... -
java多线程间的通信实例
2018-07-13 11:00 1373----线程间的通信 public class ListAd ... -
volatile关键字
2018-07-12 11:20 601volatile:使变量在多个线程间可见 public c ... -
java根据百度url获取真正的网页地址
2018-07-09 11:26 938/** * 根据百度url,获取原本url * @th ... -
java中的base64字符流与图片的相互转换
2018-06-29 13:27 1217//base64字符串转化成图片 public sta ... -
java去除图片水印的解决办法
2018-06-28 10:54 3283原文地址:http://www.oicqzone.com/pc ... -
java中的中文字符转URLEncode
2018-06-26 11:26 753String urlTypeName =java.net.UR ... -
java下载图片到本地实例
2018-06-25 15:34 1317public static void main(String[ ... -
Myeclipse中如何更改jsp默认的打开方式
2018-05-04 17:44 6091.打开myeclipse 2.点击上方的 window-&g ... -
java三大范式
2018-05-02 09:50 713参考地址:https://www.cnblogs.com/ja ... -
请求中设置代理IP
2018-04-18 16:24 932(不能直接JVM设置代理 System.getProperti ... -
java获取当前时间的时间戳
2018-04-08 09:25 1455package com.teamdev.jxbrowser.c ... -
java获取IP地址(windos,linux)皆可
2018-03-28 09:44 766package com.teamdev.jxbrowser.c ... -
post 请求
2018-02-05 16:32 488public static void trustEveryo ... -
java robot控制鼠标和键盘(笔记本中打印 i love you)(滑动)
2018-01-25 16:57 2052package robot_java; import jav ... -
java ascii转中文(ascii转utf-8)清测好用
2018-01-24 17:41 2940package com.teamdev.jxbrowser.c ...
相关推荐
简单课程设计学生管理系统,适合初学者 c++ 支持简单功能如下 1.输入学生信息 2.输出所有学生信息 3.增加新的学生信息 4.删除学生信息 5.修改学生信息 6.查询学生信息 7.根据平均分排序输出 0.退出
基于C51单片机Proteu仿真实例及软件源码+文档说明 之-电子琴.zip
均包含代码,文章,部分项目包含ppt
基于java的智乐健身后台管理系统设计与实现.docx
基于java的鲜花销售管理系统设计与实现.docx
内容概要:本文回顾了近年来关于数字孪生(Digital Twin)的概念和技术的发展历程,并详尽介绍了这种技术在未来车间中的潜在应用场景和需克服的难关。数字孪生是一种用于集成物理和虚拟系统的技术手段,它能够在产品设计、智能生产和预防性维护等多个领域发挥作用。 适合人群:研究人员和工程师们希望更好地理解数字孪生的基本理论与具体应用实践。 使用场景及目标:涵盖了从产品的设计、制造过程到服役阶段故障预测的全过程,并探讨了基于DT的具体实施路径。 其他说明:强调了信息物理系统的交互融合是DT成功部署的基础,而建立高准确度的多维虚拟模型、孪生数据驱动和实现动态实时交互将是推进这一前沿概念向前发展的关键。
管理员能够查看、添加、修改和删除景点分类信息,景点分类管理 用户在系统前台可查看系统信息,包括首页、景点信息、酒店信息以及客房信息等 用户要登录界面可输入用户名、密码,点击登录按钮进行登录系统 项目关键技术 开发工具:IDEA 、Eclipse 编程语言: Java 数据库: MySQL5.7+ 后端技术:ssm 前端技术:Vue 关键技术:springboot、SSM、vue、MYSQL、MAVEN 数据库工具:Navicat、SQLyog
关键字:UTM/企业防火墙/NGFW 功能:vpn,sdwan,无线控制器,ldap,双因子认证,nat/透明,终端控制,av防病毒,ips入侵检测,应用控制,web过滤, FortiGate UTM/NGFW产品 ①端口:8口、16口、24口、48口 ②层数:二层(接入层交换机、傻瓜式交换机)、三层(核心交换机、汇聚交换机) ③是否网管 网管: 非网管(傻瓜式交换机,即插即用) WEB网管(S1720GW系列) 全网管(S1720GFR系列,S2700以上的型号都为全网管) ④速率:百兆、千兆、万兆等 1.带机量(支持用户数) 2.端口数 3.吞吐量,并发连接数 4.功能 功能差异须知 NG-xxxx产品特有功能 TG-xxxx&NG-xxxx共有功能 TG-xxxx产品特有功能 FW:网络接入、安全防护、高可用性、身份认证、系统服务、系统管理 ●应用层DDOS攻击防护 负载均衡:多链路负载均衡与备份、多链路智能选路技术、多算法的服务器负载均衡 ●异常行为分析:内置统计只能算法,智能学习
简化设计,轻松管理 一键设计:快速创建和管理SQLite3数据库,简化数据库设计流程。 高效查询:强大的查询功能,帮助您轻松处理复杂的SQL语句。 功能全面,灵活便捷 可视化界面:直观的图形界面,让您无需编写繁琐的SQL代码,即可完成数据库设计。 数据同步:支持实时数据同步,确保您的数据库始终保持最新状态。 高度兼容,广泛适用 跨平台支持:适用于Windows、Mac和Linux等多种操作系统,满足不同开发环境的需求。 多语言集成:与C、C++等主流编程语言无缝对接,提高开发效率。 安全可靠,稳定运行 数据备份:内置数据备份与恢复功能,保障数据安全。 性能优化:优化数据库结构,提升查询速度和存储效率。
小程序-滴滴作业.zip 小程序-滴滴作业.zip 小程序-滴滴作业.zip
地线贴标_复制.ezd
Chrome主题-开阔绿地草地主题
基于java校园兼职平台设计与实现.docx
基于java的旅游管理系统设计与实现.docx
基于java的技术大健康综合咨询问诊平台的设计与实现.docx
均包含代码,文章,部分项目包含ppt
项目工程资源经过严格测试可直接运行成功且功能正常的情况才上传,可轻松复刻,拿到资料包后可轻松复现出一样的项目,本人系统开发经验充足(全领域),有任何使用问题欢迎随时与我联系,我会及时为您解惑,提供帮助。 【资源内容】:包含完整源码+工程文件+说明(如有)等。答辩评审平均分达到96分,放心下载使用!可轻松复现,设计报告也可借鉴此项目,该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的。 【提供帮助】:有任何使用问题欢迎随时与我联系,我会及时解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 下载后请首先打开README文件(如有),项目工程可直接复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用。
基于java的共享客栈管理系统设计与实现.docx
基于java的车库智能管理平台设计与实现.docx
基于java的学生宿舍管理设计与实现.docx