博客
关于我
Java--多线程(1)Thread
阅读量:338 次
发布时间:2019-03-01

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

多线程的创建一:继承于Thread类

  • 1,创建一个继承于Thread类的子类
  • 2,重写Thread类的run()
  • 3,创建Thread类的子类对象
  • 4,通过此类对象调用start()

Thread类的常用方法:

void start();启动线程,并执行对象run()方法run();线程在被调度的时候使用String getName();返回线程的名称void setName(String name);设置该线程的名称static Thread currentThread();返回当前线程。在Thread子类中就是this,通常用于主线程和Runnable实现类static void yleld();线程让步join();当某个程序执行流中中调用其他线程的join()方法时,调用线程将被阻塞,知道join()方法加入的join线程执行完毕为止。在线程a中调用线程b中的join(),线程a就进入阻塞状态,直到线程b完全执行完以后,线程a才结束阻塞状态。static void sleep(long millis);(指定时间:毫秒)让线程休眠,一段时间内放弃对cpu的控制。

要注意:一个继承于Thread的子类对象只能start()一次!

public class TestThread {       public static void main(String[] args){           MyThread mt=new MyThread();        mt.start();        for(int i=0;i<100;i++){               System.out.println("多线程0");        }    }}class MyThread extends Thread{       @Override    public void run() {           for(int i=0;i<100;i++){               System.out.println("多线程1");        }    }}

如果我们run方法只调用一次的话,可以考虑用匿名子类的形式:

new MyThread(){               @Override            public void run() {                   for(int i=0;i<100;i++){                       System.out.println("多线程1");                }            }        }.start();

其实我们更多情况是使用匿名子类的方式调用run方法。

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

你可能感兴趣的文章
NFS的安装以及windows/linux挂载linux网络文件系统NFS
查看>>
NFS的常用挂载参数
查看>>
NFS网络文件系统
查看>>
NFS远程目录挂载
查看>>
nft文件传输_利用remoting实现文件传输-.NET教程,远程及网络应用
查看>>
NFV商用可行新华三vBRAS方案实践验证
查看>>
ng build --aot --prod生成文件报错
查看>>
ng 指令的自定义、使用
查看>>
ng6.1 新特性:滚回到之前的位置
查看>>
nghttp3使用指南
查看>>
Nginx
查看>>
nginx + etcd 动态负载均衡实践(一)—— 组件介绍
查看>>
nginx + etcd 动态负载均衡实践(三)—— 基于nginx-upsync-module实现
查看>>
nginx + etcd 动态负载均衡实践(二)—— 组件安装
查看>>
nginx + etcd 动态负载均衡实践(四)—— 基于confd实现
查看>>
Nginx + Spring Boot 实现负载均衡
查看>>
Nginx + Tomcat + SpringBoot 部署项目
查看>>
Nginx + uWSGI + Flask + Vhost
查看>>
Nginx - Header详解
查看>>
nginx - thinkphp 如何实现url的rewrite
查看>>