ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

函数式编程思想概述与函数式编程思想概述

2022-07-08 14:03:56  阅读:212  来源: 互联网

标签:Runnable 函数 Executors 编程 接口 线程 概述 ExecutorService pool


函数式编程思想概述

线程池的使用

Java里面线程池的顶级接口是java.util.concurrent.Executor,但是严格意义上讲 Executor并不是一个线程

池,而只是一个执行线程的工具。真正的线程池接口是java.util.concurrent. Executorservice。
要配置一个线程池是比较复杂的,尤其是对于线程池的原理不是很清楚的情况下,很有可能配置的线程池不是较优

的,因此在java.util.concurrent.Executors线程工厂类里面提供了一些静态工厂,生成一些常用的线程池。官方建议使用Executors工程类来创建线程池对象。
Executors类中有个创建线程池的方法如下:

  public static EkecutorService newFixedThreadPool(int nThreads):返回线程池对象。(创建的是有界线程池,也就是池中的线程个数可以指定最大数量)

  获取到了一个线程池ExecutorService对象,那么怎么使用呢,在这里定义了一个使用线程池对象的方法如下:

  public Future<?> submit(Runnable task) :获取线程池中的某一个线程对象,并执行

  Future接口∶用来记录线程任务执行完毕后产生的结果。线程池创建与使用。

  使用线程池中线程对象的步骤︰

  1.创建线程池对象。

  2.创建Runnable接口子类对象。(task)

  3.提交Runnable接口子类对象。(take task)

  4.关闭线程池(一般不做)。

  Runnable实现类代码∶

package DemoThreadPool;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

/*
线程池:JDK1.5之后提供的
java.util.concurrent.Executors :线程池的工厂类,用来生成线程池Executors类中的静态方法:
static ExecutorService newFixedThreadPool(int nThreads)创建一个可重用固定线程数的钱线程池参数∶
int nThreads:创建线程池中包含的线程数量返回值:
ExecutorService接口,返回的是ExecutorService接口的实现类对象,我们可以使用ExecutorService接口接收(面向接口编程)
java.utiL.concurrent.ExecutorService:线程池接口
用来从线程池中获取线程,调用start方法,执行线程任务
submit (Runnable task)提交一个Runnable任务用于执行关闭/销毁线程池的方法
void shutdown ()
线程池的使用步骤:
1.使用线程池的工厂类Executors里边提供的静态方法newFixedThreadPool生产一个指定线程数量的钱线程池
2.创建一个类,实现Runnable接口,重写run方法,设置线程任务
3.调用ExecutorService中的方法submit,传递线程任务(实现类),开启线程,执行run方法
4.调用ExecutorService中的方法shutdoiwn销毁线程池(不建议执行)
 */
public class Demo01ThreadPool {
    public static void main(String[] args) {
        //1.使用线程池的工厂类Executors里边提供的静态方法newFixedThreadPool生产一个指定线程数量的线线程池
        ExecutorService pool = Executors.newFixedThreadPool(2);
        //3.调用ExecutorService中的方法submit,传递线程任务(实现类),开启线程,执行run方法
        pool.submit(new Demo01RunnableImpl());//pool-1-thread-1创建了一个新的线程执行
        //线程池会一直开启,使用完了线程,会自动把线程归还给线程池,线程可以继续使用
        pool.submit(new Demo01RunnableImpl());//pool-1-thread-2创建了一个新的线程执行
        pool.submit(new Demo01RunnableImpl());//pool-1-thread-2创建了一个新的线程执行


        //1/4.调用ExecutorService中的方法shutdown销毁线程池(不建议执行)
        pool.shutdown();
        pool.submit(new Demo01RunnableImpl());

    }
}

 

package DemoThreadPool;
/*
    2.创建一个类,实现Runnable接口,重写run方法,设置线程任务
 */
public class Demo01RunnableImpl implements Runnable {
    @Override
    public void run() {
        System.out.println(Thread.currentThread().getName()+"创建了一个新的线程执行");

    }
}

Lambda表达式

函数式编程思想概述

 

 

 在数学中,函数就是有输入量、输出量的一套计算方案,也就是"拿什么东西做什么事情"。相对而言,面向对象过分强调"必须通过对象的形式来做事情”,而函数式思想则尽量忽略面向对象的复杂语法―—强调做什么,而不是以什么形式做。

面向对象的思想:

做一件事情,找一个能解决这个事情的对象,调用对象的方法,完成事情.

函数式编程思想:

只要能获取到结果,谁去做的,怎么做的都不重要,重视的是结果,不重视过程

 

标签:Runnable,函数,Executors,编程,接口,线程,概述,ExecutorService,pool
来源: https://www.cnblogs.com/x3449/p/16458048.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有