博客
关于我
线程的创建方式(四)
阅读量:274 次
发布时间:2019-03-01

本文共 1520 字,大约阅读时间需要 5 分钟。

多线程的创建方式(四)

在Java中,线程的创建可以通过多种方式实现,其中一种常见的方式是使用ExecutorService类。这种方式提供了灵活的线程池配置选项,适用于需要多线程执行任务的场景。

具体来说,使用ExecutorService可以通过以下步骤创建线程:

  • 创建线程池:通过调用Executors.newFixedThreadPool(n)创建一个固定大小的线程池,其中n表示线程池中保留的核心线程数。例如,Executors.newFixedThreadPool(10)会创建一个最多保留10个线程的线程池。

  • 配置线程池属性:可以通过线程池的方法设置线程池的属性,比如setCorePoolSize设置核心线程池的大小,setKeepAliveTime设置线程的保活时间等。

  • 执行任务:通过service.execute(task)提交一个Runnable任务执行,或者通过service.submit(result)提交一个带有返回值的Callable任务执行。

  • 关闭线程池:在不再需要线程池的情况下,调用service.shutdown()关闭线程池。

  • 需要注意的是,线程池的关闭操作是异步的,一次关闭操作只能关闭部分运行中的任务。在实际应用中,可能需要处理线程池关闭后的相关逻辑。

    以下是一个简单的示例代码:

    package com.ran;import java.util.concurrent.*; import java.util.concurrent.locks.ReentrantLock;public class ran {    public static void main(String[] args) {        ExecutorService service = Executors.newFixedThreadPool(10);        ThreadPoolExecutor service1 = (ThreadPoolExecutor) service;        // 设置线程池属性        service1.setCorePoolSize(15);        service1.setKeepAliveTime();        // 创建并执行Runnable任务        service.execute(new DuoXiancheng());        service.shutdown();        // 提交Callable任务        service.submit(new Callable() {            public Object call() {                // 可以执行其他任务                return null;            }        });    }}class DuoXiancheng implements Runnable {    @Override    public void run() {        for (int i = 0; i <= 100; i++) {            if (i % 2 == 0) {                System.out.println(Thread.currentThread().getName() + " " + i);            }        }    }}

    通过以上方式,可以轻松地创建和管理多线程任务,线程池提供了一种高效的多线程执行方式。

    转载地址:http://mkox.baihongyu.com/

    你可能感兴趣的文章
    No qualifying bean of type XXX found for dependency XXX.
    查看>>
    No resource identifier found for attribute 'srcCompat' in package的解决办法
    查看>>
    no session found for current thread
    查看>>
    No toolchains found in the NDK toolchains folder for ABI with prefix: mips64el-linux-android
    查看>>
    NO.23 ZenTaoPHP目录结构
    查看>>
    NO32 网络层次及OSI7层模型--TCP三次握手四次断开--子网划分
    查看>>
    NoClassDefFoundError: org/springframework/boot/context/properties/ConfigurationBeanFactoryMetadata
    查看>>
    Node JS: < 一> 初识Node JS
    查看>>
    Node-RED中使用JSON数据建立web网站
    查看>>
    Node-RED中使用json节点解析JSON数据
    查看>>
    Node-RED中使用node-random节点来实现随机数在折线图中显示
    查看>>
    Node-RED中使用node-red-browser-utils节点实现选择Windows操作系统中的文件并实现图片预览
    查看>>
    Node-RED中使用Notification元件显示警告讯息框(温度过高提示)
    查看>>
    Node-RED中实现HTML表单提交和获取提交的内容
    查看>>
    Node.js 函数是什么样的?
    查看>>
    Node.js 历史
    查看>>
    Node.js 实现类似于.php,.jsp的服务器页面技术,自动路由
    查看>>
    node.js 怎么新建一个站点端口
    查看>>
    Node.js 文件系统的各种用法和常见场景
    查看>>
    node.js 简易聊天室
    查看>>