编程语言
首页 > 编程语言> > 函数式编程思想概述与函数式编程思想概述

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

作者:互联网

函数式编程思想概述

线程池的使用

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