博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
最近在研究多线程,浅谈JAVA中多线程的几种实现方式
阅读量:6215 次
发布时间:2019-06-21

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

 

 

多线程的实现方式:

  个人认为,要说多线程的实现方式,万变不离其宗,最基本的就是两种1.继承Thread类;2.实现runnable接口,本质上来说就是用来启动线程执行任务的过程,具体来说的话,通过这两周方式变种为多种实现方式。此处简单举例最基本的两类类

1.继承Thread类

  

     运行结果:

  

  这里要注意,在启动线程的时候,我们并不是调用线程类的run方法,而是调用了线程类的start方法。这块实际上是用了设计模式中的模板方法模式,Thread类作为模板,而run方法是在变化的因此放到子类。

2.实现Runnable

  其实Runnable就是一个线程任务,线程任务和线程的控制分离,这也就是上面所说的解耦。我们要实现一个线程,可以借助Thread类,Thread类要执行的任务就可以由实现了Runnable接口的类来处理。 这就是Runnable的精髓之所在!

使用Runnable实现上面的例子步骤如下:

  定义一个类实现Runnable接口,作为线程任务类

  重写run方法,并实现方法体,方法体的代码就是线程所执行的代码
  定义一个可以运行的类,并在main方法中创建线程任务类
  创建Thread类,并将线程任务类做为Thread类的构造方法传入
  启动线程

  

  运行结果

  

这块简单说下我的理解吧,线程的运行和线程的控制分离的,这一点还是很有用的,一个任务,我们可以通过多线程的形式来进行实现,当数据量多,或者业务需求中,接口调用频繁,多线程是至关重要的,但是切记线程安全问题,线程还可以通过内部类,定时器的形式来实现的,最后再说一点,可以有带返回值的多线程实现方式哟。这块我就不详说了  有好多博主有具体写过。有兴趣的可以去看下,明天准备就最近的业务需要,多次接口调用导致的效率问题,利用线程池效果明显体会,简单说下线程池的原理及使用场景优缺点,bingo  goodnight???

 

转载于:https://www.cnblogs.com/flovesh/p/9893359.html

你可能感兴趣的文章
数值计算---基于梯度的优化方法
查看>>
Factory Method Pattern(工厂方法模式)——莫勇鹏老师
查看>>
test
查看>>
定义一个健壮的Android Service (IntentService)类
查看>>
jeecg3.5.0-maven版本-开发环境搭建步骤-myeclipse
查看>>
耐思尼克今起开放CN域名个人注册
查看>>
CentOS 5.5下安装MySQL 5.5全过程分享
查看>>
scala第八天
查看>>
JAVA图书管理系统汇总共27个 ——下载目录
查看>>
Linux下将ISO文件安装为本地YUM源
查看>>
flash light
查看>>
PullableView
查看>>
IT人不要一直做技术
查看>>
opencv编译打包指令
查看>>
html5 canvas详解
查看>>
打包war 提示xxx v2不存在解决方法
查看>>
strongswan ikev2 server on ubuntu 14.04
查看>>
javascript操作DOM
查看>>
Hadoop环境配置
查看>>
我的友情链接
查看>>