首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

java基础|自定义java线程

线程创建的参数 在创建线程的各种方式中我们有讲到过通过创建线程来完成异步操作,但实际上jdk提供的Executors来创建线程都还有些缺陷,线程有以下几个参数: 代码节选自源码ThreadPoolExecutor.java...可以自定义名字等等 handler:在线程和队列满的时候,如何处理新到来的任务 jdk自带线程的缺陷 自带的线程主要是通过Executors来初始化. newCachedThreadPool 通过...TimeUnit.MILLISECONDS, new LinkedBlockingQueue()); } 自定义线程...通过对自带的线程的分析,我们知道自定义线程主要是对池子的最大数量和等待队列的最大数量做好限制,当然还有自定义的失败策略(以后单写个DEMO讲)代码如下: /** * @author https...,在小型开发中使用系统自带的线程是没问题的,但有时候在生产环境中,特别是同步一些东西的时候,量级比较大,这时候使用系统自带的线程难免会有些问题,这时候就需要自定义线程了,加油吧,少年!

1.2K21

Java线程实现原理之自定义线程(一)

线程好处: 1.降低资源 => 重复利用机制 (降低创建线程和销毁线程) 2.提高响应效率 => 当任务到达时,任务可以不需要等待去创建线程就可以执行 3.方便管理...Java线程就是Thread类或其子类的一个实例。 也就是说你不必关注线程对象是用哪种方法创建的。...一个任务可以是读取数据库中的一条记录, 也可以是FTP传输一批文件,FTP传输一个文件…… 1 //创建线程四种方式: 2 //1.可缓存线程,如果线程长度超过处理需要,可灵活回收空闲线程...3 //2.定长线程,可控制线程最大并发数,超出的线程会在队列中等待。 4 //3.可定时线程,支持定时及周期性任务执行。...5 //4.单例线程,它只会用唯一的工作线程来执行任务,保证所有任务按照指定顺序(FIFO, LIFO, 优先级)执行。

4K20
您找到你想要的搜索结果了吗?
是的
没有找到

Java线程】“打工人”初识线程自定义线程实战

理论 聊一下为什么要使用线程?...在Java中万物皆对象,那么线程也是一个对象,Java线程是对于操作系统线程的封装,创建Java线程也需要消耗操作系统的资源,因此就有了线程。 原理 线程创建 首先了解一下线程创建以及工作原理。...还支持自定义拒绝策略,我们实现RejectExecutionHandler接口即可; 参数设置 上面我们了解了线程的参数、工作流程、拒绝策略,下面我们了解一下如何设置参数能够达到线程的最大利用率呢?...线程的大小一旦达到最大值就会保持不变,如果某个线程因为执行异常而结束,那么线程会补充一个新线程。 ? newSingleThreadExecutor 创建一个单线程线程。...taskMap = new LinkedHashMap(); idList.forEach(e -> taskMap.put(e, Boolean.FALSE)); //自定义线程

56140

Java 并发编程】线程机制 ( 线程阻塞队列 | 线程拒绝策略 | 使用 ThreadPoolExecutor 自定义线程参数 )

文章目录 一、线程阻塞队列 二、拒绝策略 三、使用 ThreadPoolExecutor 自定义线程参数 一、线程阻塞队列 ---- 线程阻塞队列是线程创建的第 5 个参数 : BlockingQueue...: 有优先级的阻塞队列 ; 阻塞队列吞吐量 : SynchronousQueue > LinkedBlockingQueue > ArrayBlockingQueue ; 二、拒绝策略 ---- 线程拒绝策略是线程创建的第...final RejectedExecutionHandler defaultHandler = new AbortPolicy(); 三、使用 ThreadPoolExecutor 自定义线程参数...(ThreadPoolExecutor.java:823) at java.util.concurrent.ThreadPoolExecutor.execute(ThreadPoolExecutor.java...:1369) at Main.main(Main.java:16) 线程 ID : pool-1-thread-3 , 线程索引 : 2 线程 ID : pool-1-thread-1 , 线程索引

1.4K10

java如何创建线程_java线程状态

请点击http://www.captainbed.net 1、为什么要用线程线程提供了一种限制和管理资源(包括执行一个任务)。每个线程还维护一些基本统计信息,例如已完成任务的数量。...这里借用《Java并发编程的艺术》,来说一下使用线程的好处: 降低资源消耗:通过重复利用已创建的线程降低线程创建和销毁造成的消耗。...4、如何创建线程 《阿里巴巴Java开发手册》中强制线程不允许使用 Executors 去创建,而是通过 ThreadPoolExecutor 的方式,这样的处理方式让写的同学更加明确线程的运行规则...若多余一个任务被提交到该线程,任务会被保存在一个任务队列中,待线程空闲,按先入先出的顺序执行队列中的任务。 CachedThreadPool:该方法返回一个可根据实际情况调整线程数量的线程。...线程线程数量不确定,但若有空闲线程可以复用,则会优先使用可复用的线程。若所有线程均在工作,又有新的任务提交,则会创建新的线程处理任务。所有线程在当前任务执行完毕后,将返回线程进行复用。

1K10

java创建线程代码_java手写线程

, 当提交一个任务到线程的时候,线程会创建一个线程来执行任务,即使当前线程已经存在空闲线程,仍然会创建一个线程,等到需要执行的任务数大于线程基本大小时就不再创建。...如果调用线程的prestartAllCoreThreads()方法,线程会提前创建并启动所有的基本线程。...maximumPoolSizeSize 线程最大数量,线程允许创建的最大线程数,如果队列满了,并且已创建的线程数小于最大线程数,则线程会再创建新的线程执行任务。...饱和策略 当队列和线程都满了,说明线程处于饱和的状态,那么必须采取一种策略处理提交的新任务。...addWorker(command, false)) reject(command); } 参考文档 https://docs.oracle.com/javase/8/docs/api/java/util

73230

java线程

newWorkStealingPool(int parallelism),Java 8 才加入这个创建方法,其内部会构建ForkJoinPool,利用Work-Stealing算法,并行地处理任务,不保证处理顺序...首先看看线程框架图: ? 线程框架 应用与线程的交互和线程的内部工作过程如下图所示: ?...内部的“线程”,这是指保持工作线程的集合(是一个HashSet),线程需要在运行过程中管理线程创建、销毁。线程的工作线程被抽象为静态内部类 Worker,基于AQS实现。...如果任务提交时被拒绝,比如线程已经处于 SHUTDOWN 状态或者队列已经满了,需要为其提供处理逻辑,Java 标准库提供了类似ThreadPoolExecutor.AbortPolicy等默认实现,...也可以按照实际需求自定义

83220

Java线程

Java线程 一、介绍 线程,顾名思义,这是管理一堆线程而出现的对象。与数据库的连接一致,它的出现解决了线程的频繁创建和销毁,从而浪费大量资源的问题。...所以,线程池中有提前创建好的线程,使用时直接分配获取,使用完再由线程管理是否销毁。...优点 降低资源消耗,也就是不需要重复多次的创建线程 更好的管理线程 比如可以获取当前运行的线程是什么 还在等待执行的任务有什么 二、使用线程 在JDK5起提供了线程的对象,ExecutorService...和Executors 其中,ExecutorService和它的子类ThreadPoolExecutor是线程的关键 而Executors是对应的工具类,里面有些工厂方法可以快速创建线程 查看ThreadPoolExecutor...当线程所有的线程都繁忙运行时,新添加的执行任务会暂时保留至此队列 threadFactory 创建线程线程工厂 handler 拒绝策略。

48920

java线程

(每个线程需要大约1MB内存,线程开的越多,消耗的内存也就越大,最后死机);   Java里面线程的顶级接口是Executor,但是严格意义上讲Executor并不是一个线程,而只是一个执行线程的工具...要配置一个线程是比较复杂的,尤其是对于线程的原理不是很清楚的情况下,很有可能配置的线程不是较优的,因此在Executors类里面提供了一些静态工厂,生成一些常用的线程。...每次提交一个任务就创建一个线程,直到线程达到线程的最大值。线程的大小一旦达到最大值就会保持不变,如果某个线程因为执行异常而结束,那么线程会补充一个新线程。...此线程不会对线程大小做限制,线程大小完全依赖于操作系统(或者说JVM)能够创建的最大线程大小。   ...package threadpool; import java.util.concurrent.ScheduledThreadPoolExecutor; import java.util.concurrent.TimeUnit

809110

Java线程

概述:         线程,从字面含义来看是管理同一组同构工作线程的资源。...线程与工作队列是密切相关的, 工作队列保存了所有等待执行的任务, 工作线程从工作队列中获取任务并执行。         通过重用线程而不是创建线程的方式, 这样做的好处是: ①....它会创建一个固定长度的线程, 每提交一个任务就会创建一个线程,直到达到最大线程数为止。...这时候线程的规模就不会变化,需要注意的是当某个线程因发生了未预期的Exception而终止,这时候线程会补充一个新的线程。     ②. newCachedThreadPool。...它将创建一个可缓存的线程,当线程的规模大于当前需要处理的任务时会进行回收空闲的线程, 当任务增加时会动态增加线程数,  线程的规模不受限制。

78460

java线程

4)、线程 方式 1 和方式 2:主进程无法获取线程的运算结果。...,线程就会使用拒绝策略 运行流程 1、线程创建,准备好 core 数量的核心线程,准备接受任务 2、新的任务进来,用 core 准备好的空闲线程执行。...3、常见的 4 种线程   newCachedThreadPool  创建一个可缓存线程,如果线程长度超过处理需要,可灵活回收空闲线程,若 无可回收,则新建线程。...4、开发中为什么使用线程  降低资源的消耗  通过重复利用已经创建好的线程降低线程的创建和销毁带来的损耗  提高响应速度  因为线程池中的线程数没有超过线程的最大上限时,有的线程处于等待分配任务...无限的创建和销毁线程不仅消耗系统资源,还降低系统的稳定性,使 用线程进行统一分配

13630

java线程

一简介 线程的使用在java中占有极其重要的地位,在jdk1.4极其之前的jdk版本中,关于线程的使用是极其简陋的。在jdk1.5之后这一情况有了很大的改观。...Jdk1.5之后加入了java.util.concurrent包,这个包中主要介绍java线程以及线程的使用。为我们在开发中处理线程的问题提供了非常大的帮助。...Java里面线程的顶级接口是Executor,但是严格意义上讲Executor并不是一个线程,而只是一个执行线程的工具。真正的线程接口是ExecutorService。...每次提交一个任务就创建一个线程,直到线程达到线程的最大大小。线程的大小一旦达到最大值就会保持不变,如果某个线程因为执行异常而结束,那么线程会补充一个新线程。...此线程不会对线程大小做限制,线程大小完全依赖于操作系统(或者说JVM)能够创建的最大线程大小。 4.newScheduledThreadPool 创建一个大小无限的线程

1.1K60

Java线程

: 因为创建线程需要比较大的开销,并且线程数太多的情况下上下文切换比较频繁,所以我们希望有一种机制来改善它,这就是线程,改善的核心就是控制线程的数量,通过暴露接口,可以满足用户创建不同场景下的线程...,提交一个任务时,如果线程池中的线程数没有达到核心线程数,则会创建一个新的线程 maximumPoolSize: 最大线程,工作队列满了的情况下,如果线程池中的线程数没有达到最大线程数,则会创建一个新线程...#addWorkerFailed 执行到这里,说明线程可能已经出现了问题,这时候需要回滚之气那的操作.即恢复workerCount的值,然后将该Worker从workers中移除,并尝试停止线程 private...在创建线程的时候,有提到一个参数:空闲时间,这个空闲时间是什么意思呢?...(即take),反之亦然 优缺点 适合执行时间比较短的任务,这种情况下,很多线程可以被复用,避免每次都创建大量线程的开销 但在任务执行时间比较长的情况,由于该线程线程数没有限制,可能会创建非常多的线程

91410

Java线程(六):线程

自JDK5之后,Java推出了一个并发包,java.util.concurrent,在Java开发中,我们接触到了好多的技术,String类的对象、Integer的共享、连接数据库的连接...我们的web项目都是部署在服务器上,浏览器端的每一个request就是一个线程,那么服务器需要并发的处理多个请求,就需要线程技术,下面来看一下Java并发包下如何创建线程。        ...创建一个可重用固定线程集合的线程,以共享的无界队列方式来运行这些线程。 [java] view plaincopyprint?...创建一个可根据需要创建新线程线程,但是在以前构造的线程可用时将重用它们。 [java] view plaincopyprint?...创建一个可安排在给定延迟后运行命令或者定期地执行的线程。 [java] view plaincopyprint?

1.1K00

java线程拒绝策略_Java线程拒绝策略

e.isShutdown()) { r.run(); } } } CallerRunsPolicy顾名思义就是调用者自己执行,看实现就知道,如果线程还没有关闭,就让将要被执行的线程自己调用自己的run...拒绝策略与模式 从线程的拒绝策略实现上也体现了面向对象的思想,把拒绝策略抽象在RejectedExecutionHandler接口中,ThreadPoolExecutor关联(更加具体的来说是聚合aggregation...自定义拒绝策略 既然设计上使用的是策略模式,那么对于我们来说扩展就是相当容易的事情了,简单来一个例子测试一下扩展线程的策略模式。...总结 Java提供的4中默认策略分别是CallerRunsPolicy如果线程没有关闭直接当前线程执行run方法,AbortPolicy抛出异常,DiscardPolicy丢弃任务,DiscardOldestPolicy...Java线程拒绝策略使用的是策略模式,抽象在RejectedExecutionHandler,如果需要扩展只需要实现RejectedExecutionHandler接口就可以了。

83330

Java线程_Java线程的大小与线程死锁

Java线程的大小与线程死锁 优化线程大小 线程大小对系统性能是有一定影响的,过大或者过小都会无法发挥最优的系统性能, 线程大小不需要非常精确,只要避免极大或者极小的情况即可, 一般来说,线程大小需要考虑...Java线程异常处理 在使用ThreadPoolExecutor进行submit提交任务时,有的任务抛出了异常,但是线程并没有进行提示,即线程把任务中的异常给吃掉了,可以把submit提交改为execute...执行,也可以对ThreadPoolExecutor线程进行扩展.对提交的任务进行包装: package com.wkcto.threadpool; import java.util.concurrent....*; /** * 自定义线程类,对ThreadPoolExecutor进行扩展 */ public class Test08 { //自定义线程类 private static...ThreadPoolExecutor(0, Integer.MAX_VALUE, 0, TimeUnit.SECONDS, new SynchronousQueue()); //使用自定义线程

86340
领券