计算机的线程2

1.创建线程

方法1 继承Thread类

继承Thread类来创建一个线程类。

class MyThread extends Thread {
     @Override
     public void run () {
        System.out.println("这里是线程运行的代码");
     }
}

 创建MyThread类的实例

MyThread t = new MyThread( );

调用start方法启用线程

t.start ( );  //线程开始运行
方法2 实现Runnable 接口

1.实现Runnable接口

class MyRunnable implements Runnable {
    @overrride
    public void run ( ) {
       System.out.println ("这里是线程运行的代码");
    }
}

2.创建Thread 类实例,调用Thread的构造方法时将Runnable对象作为target

参数。

Thread t = new Thread(new MyRunnable( ));

3.调用start方法

t.start( );  // 线程开始运行
对比上面两种方法:

1.继承Thread类,直接使用this就表示当前线程对象的引用。

2.实现Runnable接口,this表示的是MyRunnable的引用。需要使用Thread.currentThread()。

其他变形

1.匿名内部类创建Thread子类对象

// 使用匿名类创建Thread子类对象
Thread t1 = new Thread ( ) {
    @override
    public void run ( ) {
       System.out.println ("使用匿名类创建 Thread子类对象");
    }
};

2.匿名内部类创建Runnable子类对象

 // 使用匿名类创建 Runnable子类对象
Thread t2 = new Thread(new Runnable( )) {
   @override
   public void run ( ) {
      System.out.println("使用匿名类创建 Runnable 子类对象");
   }
}

3.lambda表达式创建Runnable子类对象

2.多线程的优势-增加运行速度

可以观察多线程在一些场合下是可以提高程序的整体运行效率的。

使用System.nanoTime( ) 可以记录当前系统的纳秒级时间戳。

serial 串行的完成一系列的运算。concurrency 使用两个线程并行的完成同样的运算。

public class ThreadAdvantage {
     // 多线程并不⼀定就能提⾼速度,可以观察,count 不同,实际的运⾏效果也是不同的
     private static final long count = 10_0000_0000;

     public static void main(String[] args) throws InterruptedException {
         // 使⽤并发⽅式
         concurrency();
         // 使⽤串⾏⽅式
         serial();
     }

      private static void concurrency() throws InterruptedException {
          long begin = System.nanoTime();
 
          // 利⽤⼀个线程计算 a 的值
           Thread thread = new Thread(new Runnable() {
              @Overrid
              public void run() {
                  int a = 0;
                  for (long i = 0; i < count; i++) {
                       a--;
                  }
             }
       });
       thread.start();
       // 主线程内计算 b 的值
       int b = 0;
       for (long i = 0; i < count; i++) {
        b--;
       }
        // 等待 thread 线程运⾏结束
        thread.join();
 
        // 统计耗时
        long end = System.nanoTime();
        double ms = (end - begin) * 1.0 / 1000 / 1000;
         System.out.printf("并发: %f 毫秒%n", ms);
     }

     private static void serial() {
          // 全部在主线程内计算 a、b 的值
          long begin = System.nanoTime();
          int a = 0;
          for (long i = 0; i < count; i++) {
               a--;
          }
          int b = 0; 
          for (long i = 0; i < count; i++) {
                b--;
          }
          long end = System.nanoTime();
          double ms = (end - begin) * 1.0 / 1000 / 1000;
          System.out.printf("串⾏: %f 毫秒%n", ms);
       }
   }

并发:399.651856毫秒

串行:720.616811毫秒

  • 6
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值