zoukankan      html  css  js  c++  java
  • Java-线程Thread

    1.Java的线程是通过java.lang.Thread类来实现的。
    2.VM启动时会有一个由主方法(public static void main() {})所定义的线程。
    3.可以通过创建Thread的实例来创建新的线程;
    4.每个线程都是通过某个特定Thread对象所对应的方法run()来完成其操作的,方法run()称为线程体;
    5.通过调用Thead类的start()方法来启动一个线程。


    线程:程序内部的顺序控制流。

    线程和进程的区别:
      每个进程都有独立的代码和数据空间(进程上下文),进程间的切换会有较大的开销;
      线程可以看成轻量级的进程,同一类线程共享代码和数据空间,每个线程有独立的运行栈和程序计数器,线程切换的开销小;
      多进程:在操作系统中能同时运行多个任务(程序);
      多线程:在同一应用程序中有多个顺序流同时执行;

    线程的创建和启动:
      创建有二种方法
        第一种:
          1:定义线程类实现Runnable接口;
          2:Thread myThread = new Thead (target) //target为Runnable接口类型。
          3:Runnable中只有一个方法:public void run();用来定义线程运行体。
          4:使用Runnable接口可以为多个线程提供共享的数据。
          5:在实现Runnable接口的类的run方法定义中可以使用Thread的静态方法;
            public static Thread currentThread()获取当前线程的引用。

      第二种:
        1:可以定义一个Thread的子类并重写其run方法如:
          class MyThread extends Thead{
            public void run() {......}
          }
        2:然后生成类的对象:MyThread myThread = new MyThread(...)

    例子:

    例一:实现接口方法  推荐使用。

    public class TestThread {

      public static void main(String[] args) {
        Runner1 r = new Runner1();
        Thread t = new Thread(r);
        t.start();

        for(int i=0; i<100; i++){
          System.out.println("Main Thread:-----" + i);
        }
      }
    }

    class Runner1 implements Runnable{
      public void run(){
        for(int i=0; i<100; i++){
          System.out.println("Runnner1:-----" + i);
        }
      }
    }

    例二。继承方式:

    public class TestThread_150304 {
      public static void main(String[] args) {
        Runner1 r = new Runner1();
        r.start();
        for(int i=0; i<100; i++){
          System.out.println("Main Thread:-----" + i);
        }
      }
    }

    class Runner1 extends Thread{
      public void run(){
        for(int i=0; i<100; i++){
          System.out.println("Runnner1:-----" + i);
        }
      }
    }

  • 相关阅读:
    HGOI 20191029am 题解
    『ZJOI2019 D2T2』语言
    『NOIP 2019Day2 T3』 保卫王国(defense)
    『HGOI 20190917』Lefkaritika 题解 (DP)
    『HGOI 20190917』Cruise 题解 (计算几何+DP)
    HGOI 20190830 题解
    『Codeforces 1186E 』Vus the Cossack and a Field (性质+大力讨论)
    HGOI 20190828 题解
    BZOJ 1934 善意的投票
    BZOJ 2763 飞行路线 BFS分层
  • 原文地址:https://www.cnblogs.com/lzhat/p/4312566.html
Copyright © 2011-2022 走看看