博客
关于我
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/

你可能感兴趣的文章
Netty心跳检测机制
查看>>
netty既做服务端又做客户端_网易新闻客户端广告怎么做
查看>>
Netty核心模块组件
查看>>
Netty框架内的宝藏:ByteBuf
查看>>
Netty框架的服务端开发中创建EventLoopGroup对象时线程数量源码解析
查看>>
Netty源码—1.服务端启动流程一
查看>>
Netty源码—1.服务端启动流程二
查看>>
Netty源码—2.Reactor线程模型一
查看>>
Netty源码—2.Reactor线程模型二
查看>>
Netty源码—3.Reactor线程模型三
查看>>
Netty源码—3.Reactor线程模型四
查看>>
Netty源码—4.客户端接入流程一
查看>>
Netty源码—4.客户端接入流程二
查看>>
Netty源码—5.Pipeline和Handler一
查看>>
Netty源码—5.Pipeline和Handler二
查看>>
Netty源码—6.ByteBuf原理一
查看>>
Netty源码—6.ByteBuf原理二
查看>>
Netty源码—7.ByteBuf原理三
查看>>
Netty源码—7.ByteBuf原理四
查看>>
Netty源码—8.编解码原理一
查看>>