当前位置: 首页 > news >正文

网站排名消失网红推广

网站排名消失,网红推广,wordpress主题上传图片教程,郑州网站建设哪个好系列文章目录 第一章 Java线程池技术应用 文章目录 系列文章目录[TOC](文章目录) 前言1、Java创建线程方式回顾1.1、继承Thread类(只运行一次)1.1.1、改造成主线程常驻,每秒开启新线程运行1.1.2、匿名内部类1.1.3、缺点1.1.4、扩展知识:Java内部类1.1.4…

系列文章目录

第一章 Java线程池技术应用

在这里插入图片描述


文章目录

  • 系列文章目录
    • @[TOC](文章目录)
  • 前言
  • 1、Java创建线程方式回顾
    • 1.1、继承Thread类(只运行一次)
      • 1.1.1、改造成主线程常驻,每秒开启新线程运行
      • 1.1.2、匿名内部类
      • 1.1.3、缺点
      • 1.1.4、扩展知识:Java内部类
        • 1.1.4.1、静态内部类
        • 1.1.4.2、匿名内部类
    • 1.2、实现Runnable接口
      • 1.2.1、普通类实现Runnable接口
      • 1.2.2、匿名方式创建Runnable实现类
      • 1.2.3、使用Lambda方式创建匿名Runnable类
      • 1.2.4、缺点
      • 1.2.5、扩展Lambda表达式
    • 1.3、实现Callable接口
      • 1.3.1、普通类实现Callable接口
  • 2、线程池
    • 2.1、五种创建线程的方式
    • 2.2、new ThreadPoolExecutor()创建线程
      • 2.2.1、拒绝策略

前言

介绍Java的线程、线程池等操作

1、Java创建线程方式回顾

1.1、继承Thread类(只运行一次)

public class ThreadTest extends Thread{@Overridepublic void run() {System.out.println(Thread.currentThread().getName());}public static void main(String[] args) {new ThreadTest().start();}
}

1.1.1、改造成主线程常驻,每秒开启新线程运行


import java.util.Date;@Slf4j
public class ThreadTest extends  Thread{@Overridepublic void run() {log.info("线程名称:{} , 当前时间:{}" , Thread.currentThread().getName() , new Date().getTime() );}public static void main(String[] args) {while (true) {try {new ThreadTest().start();Thread.sleep(1000);} catch (InterruptedException e) {throw new RuntimeException(e);}log.info("主线程常驻");}}}

1.1.2、匿名内部类

import lombok.extern.slf4j.Slf4j;@Slf4j
public class ThreadTest extends  Thread{public static void main(String[] args) {Thread thread = new Thread() {@Overridepublic void run() {log.info("Hello {}" , "world");}};thread.start();}}

1.1.3、缺点

继承了Thread类之后,就不能继承其他类

1.1.4、扩展知识:Java内部类

成员内部类(外部类内部使用,外部类外部使用)


import lombok.extern.slf4j.Slf4j;@Slf4j
public class Outer {public static void main(String[] args) {Inner inner = new Outer().initTest();log.info(inner.innerTest());}public Inner initTest(){Inner inner = new Inner();return  inner;}class Inner{public Inner(){}public Inner(String s){}public String innerTest(){return "Inner Hello world";}}
}

1.1.4.1、静态内部类

import lombok.extern.slf4j.Slf4j;@Slf4j
public class Outer {public static void main(String[] args) {Inner inner = new Inner();log.info(inner.innerTest());}public void initTest(){Inner inner = new Inner();}static class Inner{public Inner(){}public Inner(String s){}public String innerTest(){return "Inner Hello world";}}
}

1.1.4.2、匿名内部类

import lombok.extern.slf4j.Slf4j;@Slf4j
public class Outer {public static void main(String[] args) {Outer outer = new Outer();outer.sayHello();}public void sayHello(){IMessage iMessage = new IMessage() {//匿名类@Overridepublic String sayHello() {return "Hello world";}};log.info(iMessage.sayHello());}interface IMessage{String sayHello();}}

1.2、实现Runnable接口

1.2.1、普通类实现Runnable接口

import lombok.extern.slf4j.Slf4j;@Slf4j
public class StatSales implements Runnable{@Overridepublic void run() {log.info("统计销量");}public static void main(String[] args) {Thread thread = new Thread() {@Overridepublic void run() {log.info("Hello world");}};thread.start();}
}

1.2.2、匿名方式创建Runnable实现类

public static void main(String[] args) {Runnable runnable = new Runnable() {@Overridepublic void run() {System.out.println("统计成绩");}};new Thread(runnable).start();}

1.2.3、使用Lambda方式创建匿名Runnable类

// 使用 Lambda 匿名 Runnable 方式
Thread t3 = new Thread(() -> {
//添加业务方法…
});
// 启动线程
t3.start();

public static void main(String[] args) {Thread thread = new Thread(() -> {System.out.println("统计平均寿命");});thread.start();
}

1.2.4、缺点

不能获得程序的执行结果

1.2.5、扩展Lambda表达式

把函数作为一个方法的参数
表达式语法:

(parameters) -> expression

(parameters) ->{ statements; }

说明:

  • 可选类型声明:不需要声明参数类型,编译器可以统一识别参数值。
  • 可选的参数圆括号:一个参数无需定义圆括号,但多个参数需要定义圆括号。
  • 可选的大括号:如果主体包含了一个语句,就不需要使用大括号。
  • 可选的返回关键字:如果主体只有一个表达式返回值则编译器会自动返回值,大括号需要指定表达式返回了一个数值。
  • 举例:

    // 1. 不需要参数,返回值为 5  
    () -> 5  // 2. 接收一个参数(数字类型),返回其2倍的值  
    x -> 2 * x  // 3. 接受2个参数(数字),并返回他们的差值  
    (x, y) -> x – y  // 4. 接收2个int型整数,返回他们的和  
    (int x, int y) -> x + y  // 5. 接受一个 string 对象,并在控制台打印,不返回任何值(看起来像是返回void)  
    (String s) -> System.out.print(s)
    

    1.3、实现Callable接口

    FutureTask+Callable

    1.3.1、普通类实现Callable接口

    public class StatScore implements Callable<Double> {@Overridepublic Double call() throws Exception {//统计分数的逻辑return 88.98;}
    }
    
     public static void main(String[] args) throws ExecutionException, InterruptedException {StatScore statScore = new StatScore();//跟FutureTask 关联上FutureTask<Double> doubleFutureTask = new FutureTask<>(statScore);//跟Thread关联上Thread thread = new Thread(doubleFutureTask);thread.start();log.info(String.valueOf(doubleFutureTask.get()));}
    

    2、线程池

    线程池就是存放线程的池子,池子里存放了很多可以复用的线程。
    使用线程池的优势

  • 提高效率,创建好一定数量的线程放在池中,等需要使用的时候就从池中拿一个,这要比需要的时候创建一个线程对象要快的多。
  • 减少了创建和销毁线程的次数,每个工作线程都可以被重复利用,可执行多个任务。
  • 提升系统响应速度,假如创建线程用的时间为T1,执行任务用的时间为T2,销毁线程用的时间为T3,那么使用线程池就免去了T1和T3的时间;
  • 在这里插入图片描述

    2.1、五种创建线程的方式

    //创建一个单线程池,它只会用唯一的工作线程来执行任务,保证所有任务按照指定顺序(FIFO, LIFO, 优先级)执行
    ExecutorService executorService = Executors.newSingleThreadExecutor();
    //创建一个定长的线程池,可控制最大并发数,超出的线程进行队列等待。 ExecutorService executorService =
    Executors.newFixedThreadPool(2); //可以创建定长的、支持定时任务,周期任务执行。
    ExecutorService executorService = Executors.newScheduledThreadPool(2);
    //创建一个可以缓存的线程池,如果线程池长度超过处理需要,可以灵活回收空闲线程,没回收的话就新建线程 ExecutorService
    executorService = Executors.newCachedThreadPool(); //创建一个具有抢占式操作的线程池
    ExecutorService executorService = Executors.newWorkStealingPool();

    2.2、new ThreadPoolExecutor()创建线程

    public ThreadPoolExecutor(int corePoolSize,
    int maximumPoolSize,
    long keepAliveTime,
    TimeUnit unit,
    BlockingQueue<Runnable> workQueue,
    ThreadFactory threadFactory,
    RejectedExecutionHandler handler)
    

    参数说明:

    参数含义解释
    corePoolSize该线程池中核心线程数最大值核心线程生命周期无限,即使空闲也不会死亡
    maximumPoolSize线程总数最大值任务队列满了以后当有新任务进来则会增加一个线程来处理新任务(线程总数<maximumPoolSize )
    keepAliveTime闲置超时时间当线程数大于核心线程数时,超过keepAliveTime时间将会回收非核心线程
    unitkeepAliveTime 的单位
    workQueue线程池中的任务队列*
    threadFactory为线程池提供创建新线程的线程工厂*
    RejectedExecutionHandler饱和策略抛出异常专用,当队列和最大线程池都满了之后的饱和策略。

    在这里插入图片描述

    2.2.1、拒绝策略

    ThreadPoolExecutor的饱和策略可以通过调用setRejectedExecutionHandler来修改。JDK提供了几种不同的RejectedExecutionHandler实现,每种实现都包含有不同的饱和策略:AbortPolicy、CallerRunsPolicy、DiscardPolicy和DiscardOldestPolicy。

    拒绝策略如下:

  • CallerRunsPolicy : 调用线程处理任务
  • AbortPolicy : 抛出异常
  • DiscardPolicy : 直接丢弃
  • DiscardOldestPolicy : 丢弃队列中最老的任务,执行新任务
  •         RejectedExecutionHandler rejected = null;//默认策略,阻塞队列满,则丢任务、抛出异常rejected = new ThreadPoolExecutor.AbortPolicy();//阻塞队列满,则丢任务,不抛异常rejected = new ThreadPoolExecutor.DiscardPolicy();//删除队列中最旧的任务(最早进入队列的任务),尝试重新提交新的任务rejected = new ThreadPoolExecutor.DiscardOldestPolicy();//队列满,不丢任务,不抛异常,若添加到线程池失败,那么主线程会自己去执行该任务rejected = new ThreadPoolExecutor.CallerRunsPolicy();

    总结: 就是被拒绝的任务,直接在主线程中运行,不再进入线程池。

http://www.khdw.cn/news/68074.html

相关文章:

  • 网站怎么做h5支付宝支付搜索百度app下载
  • 黄岩做网站公司电话企业推广app
  • 优惠券网站怎么做搜索引擎营销有哪些方式
  • 一级a做爰片免费网站瑜伽怎么自己创建一个网站
  • 兴仁县城乡建设局网站seo是什么公司
  • xampp wordpress linux深圳企业seo
  • 重庆公司注册代理seo推广骗局
  • 建筑网建筑规范大全专业网站优化外包
  • 常州注册公司代办注册烟台seo外包
  • 用flask做的网站有哪些网站建设的重要性
  • 小程序开发成本宁波seo排名公司
  • 公司百度网站建设郑州seo优化培训
  • 汕头教育学会网站建设网络搜索关键词排名
  • 门户网站建设 突出服务seo全称
  • 一搜同志网站建设电话深圳白帽优化
  • 中山独立站优化快速排名工具免费
  • 做网站一年了 做个小总结什么是互联网营销
  • java一般用来做网站后台吗信息流优化师证书
  • 岳阳网站制作企业营销策划方案
  • 在直播网站做前端注意网上营销培训课程
  • 邵阳属于哪个省哪个市关键词seo排名优化
  • 网页制作网站图片网络推广外包哪个公司做的比较好
  • 免费建站网站做一个公司网站大概要多少钱
  • 个人网站 虚拟主机价格河南制作网站
  • 广东网站开发费用seo自动优化工具
  • 长沙岳麓区网站开发app下载推广平台
  • 网站制作流程 优帮云网站推荐
  • 宣城市网站集约化建设大数据营销精准营销
  • 南昌专业制作网站设计sem竞价广告
  • 西部网站邮箱登录沈阳seo顾问