博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
线程的几种实现方式?怎么启动?怎么区分?线程池?线程并库
阅读量:5167 次
发布时间:2019-06-13

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

一、实现方式

1、通过继承Thread类实现一个线程

2、通过实现Runnable接口实现一个线程

继承扩展性不强,java总支持单继承,如果一个类继承了thread就不能继承其他的类了。

二、怎么启动

Thread thread = new Thread(继承了thread的对象/实现了Runnable的对象)

thread.setName("设置一个线程名称");

thread.start();

启动线程使用start方法,而启动了以后执行的是run方法。

三、怎么区分线程?在一个系统中有很多线程,每个线程都会打印日志,我想区分是那个线程,打印怎么办?

       thread.setName("设置一个线程名称");这是一种规范,在创建线程完成后,都需要设置名称。

四、有没有使用过线程并发库

简单了解过?

java通过Executors提供了四个静态方法创建线程池,分别是:

       newCachedThreadPool:创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。

      newFixedThreadPool :创建一个定长线程池,可控制线程最大并发数,超出的线程会在队列中等待。
      newScheduledThreadPool: 创建一个定长线程池,支持定时及周期性任务执行。
      newSingleThreadExecutor: 创建一个单线程化的线程池,它只会用唯一的工作线程来执行任务,保证所有任务按照指定顺序(FIFO, LIFO, 优先级)执行。

(1). newCachedThreadPool
创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。示例代码如下:

ExecutorService cachedThreadPool = Executors.newCachedThreadPool();for (int i = 0; i < 10; i++) {    final int index = i;    try {        Thread.sleep(index * 1000);    } catch (InterruptedException e) {        e.printStackTrace();    }    cachedThreadPool.execute(new Runnable() {        @Override        public void run() {            System.out.println(index);        }    });}

线程池为无限大,当执行第二个任务时第一个任务已经完成,会复用执行第一个任务的线程,而不用每次新建线程。
 
(2). newFixedThreadPool
创建一个定长线程池,可控制线程最大并发数,超出的线程会在队列中等待。示例代码如下:

ExecutorService fixedThreadPool = Executors.newFixedThreadPool(3);for (int i = 0; i < 10; i++) {    final int index = i;    fixedThreadPool.execute(new Runnable() {        @Override        public void run() {            try {                System.out.println(index);                Thread.sleep(2000);            } catch (InterruptedException e) {                // TODO Auto-generated catch block                e.printStackTrace();            }        }    });}

因为线程池大小为3,每个任务输出index后sleep 2秒,所以每两秒打印3个数字。
定长线程池的大小最好根据系统资源进行设置。如Runtime.getRuntime().availableProcessors()。可参考PreloadDataCache。

(3) newScheduledThreadPool
创建一个定长线程池,支持定时及周期性任务执行。延迟执行示例代码如下:

ScheduledExecutorService scheduledThreadPool = Executors.newScheduledThreadPool(5);scheduledThreadPool.schedule(new Runnable() {    @Override    public void run() {        System.out.println("delay 3 seconds");    }}, 3, TimeUnit.SECONDS)

表示延迟3秒执行。
 
定期执行示例代码如下:

scheduledThreadPool.scheduleAtFixedRate(new Runnable() {@Overridepublic void run() {System.out.println("delay 1 seconds, and excute every 3 seconds");}}, 1, 3, TimeUnit.SECONDS);

表示延迟1秒后每3秒执行一次。
ScheduledExecutorService比Timer更安全,功能更强大,后面会有一篇单独进行对比。

(4)、newSingleThreadExecutor
创建一个单线程化的线程池,它只会用唯一的工作线程来执行任务,保证所有任务按照指定顺序(FIFO, LIFO, 优先级)执行。示例代码如下:

ExecutorService singleThreadExecutor = Executors.newSingleThreadExecutor();for (int i = 0; i < 10; i++) {    final int index = i;    singleThreadExecutor.execute(new Runnable() {        @Override        public void run() {            try {                System.out.println(index);                Thread.sleep(2000);            } catch (InterruptedException e) {                // TODO Auto-generated catch block                e.printStackTrace();            }        }    });}

结果依次输出,相当于顺序执行各个任务。

1、线程池的作用?

 (1)限定线程的个数,不会导致由于线程过多导致系统运行缓慢或崩溃

 (2)线程池不需要每次都去创建或销毁,节约了资源

 ( 3)线程池不需要每次都去创建 ,相应时间更快

连接池也是一样的?

 

 

 

(1). newCachedThreadPool

创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。示例代码如下:

ExecutorService cachedThreadPool = Executors.newCachedThreadPool();for (int i = 0; i < 10; i++) {    final int index = i;    try {        Thread.sleep(index * 1000);    } catch (InterruptedException e) {        e.printStackTrace();    }    cachedThreadPool.execute(new Runnable() {        @Override        public void run() {            System.out.println(index);        }    });}

线程池为无限大,当执行第二个任务时第一个任务已经完成,会复用执行第一个任务的线程,而不用每次新建线程。

 
(2). newFixedThreadPool
创建一个定长线程池,可控制线程最大并发数,超出的线程会在队列中等待。示例代码如下:

ExecutorService fixedThreadPool = Executors.newFixedThreadPool(3);for (int i = 0; i < 10; i++) {    final int index = i;    fixedThreadPool.execute(new Runnable() {        @Override        public void run() {            try {                System.out.println(index);                Thread.sleep(2000);            } catch (InterruptedException e) {                // TODO Auto-generated catch block                e.printStackTrace();            }        }    });}

因为线程池大小为3,每个任务输出index后sleep 2秒,所以每两秒打印3个数字。

定长线程池的大小最好根据系统资源进行设置。如Runtime.getRuntime().availableProcessors()。可参考PreloadDataCache。
 
(3) newScheduledThreadPool
创建一个定长线程池,支持定时及周期性任务执行。延迟执行示例代码如下:

ScheduledExecutorService scheduledThreadPool = Executors.newScheduledThreadPool(5);scheduledThreadPool.schedule(new Runnable() {    @Override    public void run() {        System.out.println("delay 3 seconds");    }}, 3, TimeUnit.SECONDS);

表示延迟3秒执行。

 
定期执行示例代码如下:

scheduledThreadPool.scheduleAtFixedRate(new Runnable() {

@Override

public void run() {
System.out.println("delay 1 seconds, and excute every 3 seconds");
}
}, 1, 3, TimeUnit.SECONDS);

表示延迟1秒后每3秒执行一次。

ScheduledExecutorService比Timer更安全,功能更强大,后面会有一篇单独进行对比。
 
(4)、newSingleThreadExecutor
创建一个单线程化的线程池,它只会用唯一的工作线程来执行任务,保证所有任务按照指定顺序(FIFO, LIFO, 优先级)执行。示例代码如下:

ExecutorService singleThreadExecutor = Executors.newSingleThreadExecutor();for (int i = 0; i < 10; i++) {    final int index = i;    singleThreadExecutor.execute(new Runnable() {        @Override        public void run() {            try {                System.out.println(index);                Thread.sleep(2000);            } catch (InterruptedException e) {                // TODO Auto-generated catch block                e.printStackTrace();            }        }    });}

结果依次输出,相当于顺序执行各个任务。

现行大多数GUI程序都是单线程的。Android中单线程可用于数据库操作,文件操作,应用批量安装,应用批量删除等不适合并发但可能IO阻塞性及影响UI线程响应的操作。

转载于:https://www.cnblogs.com/xiaonantianmen/p/9219815.html

你可能感兴趣的文章
【linux配置】VMware安装Redhat6.5
查看>>
AI自主决策——有限状态机
查看>>
Python装饰器学习笔记
查看>>
iframe父子窗口取值
查看>>
利用Python进行数据分析_Pandas_数据结构
查看>>
2018-2019 2 20175230《Java程序设计》第九周学习总结
查看>>
python3中sum
查看>>
spring声明式事务管理
查看>>
JavaScript高阶函数(Heigher-order function)
查看>>
《计算机组成原理》第6章:总线
查看>>
Nginx的反向代理的配置
查看>>
JAVA之单例模式
查看>>
关于String str =new String("abc")和 String str = "abc"的比较
查看>>
Android软件架构及子系统介绍
查看>>
《DSP using MATLAB》示例 Example 6.14、6.15
查看>>
Java命名规范
查看>>
小学生算术
查看>>
BZOJ2823: [AHOI2012]信号塔
查看>>
工厂方法模式
查看>>
Linux下安装git
查看>>