• 进程

    • 操作系统中, 并行执行的任务
  • 线程
    • 进程内部, 并行执行的任务
    • 进程包含线程
  • 线程的创建
    • 继承Thred
      • 定义 Thred 的子类
      • 重写 run() 方法
      • 在 run() 方法中的代码, 是与其他代码并行的代码
      • 线程启动后, 自动执行
      • package day1702_线程;
        
        public class Test1 {
        public static void main(String[] args) { T1 t1 = new T1();
        T1 t2 = new T1(); // 创建线程对象 t1.start(); // 启动线程后, 自动执行
        t2.start(); System.out.println("main"); } static class T1 extends Thread{ // 继承线程
        @Override
        public void run() {
        super.run(); super.setName("thred1");// 设置线程名称 super.getName();// 获取线程名 String n = super.getName(); for (int i = ; i < ; i++) {
        System.out.println(n+": "+i);
        } }
        }
        }


    • 实现 Runnable
      • 定义 Runnable 子类
      • 实现 run() 方法
      • 把 Runnable 对象, 放入Thred 线程对象启动
      • 线程启动后, 执行 Runnable 对象的 Run() 方法
      • package day1702_线程;
        
        public class Test2 {
        public static void main(String[] args) { R1 r1 = new R1();// 创建 R1 对象
        R1 r2 = new R1(); Thread t1 = new Thread(r1); // 创建线程
        Thread t2 = new Thread(r2); t1.start(); // 执行线程
        t2.start(); } static class R1 implements Runnable{
        @Override
        public void run() { // 获得 正在执行这行代码的线程对象
        Thread t = Thread.currentThread(); // 获得线程名
        String n = t.getName();
        for (int i = ; i < ; i++) {
        System.out.println(n+": "+i);
        }
        }
        } }
  •  线程的状态
    • 新生
    • 可执行
    • 阻塞
    • 执行
    • 消亡   即run()结束
  • 线程的方法
    • Thread.currentThread(); // 获得正在执行这行代码的线程对象 
    • Thread.sleep(毫秒值)    // 当前线程暂停指定的毫秒时间  
    • iterrupt() 
      • 打断一个线程的暂停状态,  被打断的线程会出现异常
      • InterruptedException
    • package day1702_线程;
      
      import java.text.SimpleDateFormat;
      import java.util.Date;
      import java.util.Scanner; public class Test3 {
      public static void main(String[] args) {
      T1 t1 = new T1();
      t1.start(); // main 线程 打断t1 线程的暂停状态
      System.out.println("按回车打断 t 线程");
      new Scanner(System.in).nextLine(); t1.interrupt(); // 打断
      } static class T1 extends Thread{
      @Override
      public void run() {
      // TODO Auto-generated method stub
      super.run(); SimpleDateFormat sdf =
      new SimpleDateFormat("HH:ss:mm"); while (true) {
      String s = sdf.format(new Date());
      System.out.println(s); // 停一秒
      try {
      Thread.sleep();
      } catch (InterruptedException e) {
      // TODO Auto-generated catch block
      e.printStackTrace(); System.out.println("谁TMD桶我");
      break; } } }
      }
      }


    • join(); //当前线程,等待被调用的线程结束
    • package day1702_线程;
      
      public class Test4 {
      public static void main(String[] args) throws InterruptedException {
      // 1000万内的质数数量 System.out.println(" 单线程");
      f1();
      System.out.println("五个线程");
      f2(); } private static void f1() throws InterruptedException {
      long t = System.currentTimeMillis(); T1 t1 = new T1(,);
      t1.start(); // 让main 线程等待 t1 结束
      t1.join();
      int r = t1.count; t = System.currentTimeMillis() - t;
      System.out.println("执行时间: "+t);
      System.out.println("质数数量: "+r);
      } private static void f2() throws InterruptedException {
      // TODO Auto-generated method stub
      long t = System.currentTimeMillis(); T1[] a = new T1[];
      for (int i = ; i < a.length; i++) {
      a[i] = new T1(*i,*(i+));
      a[i].start();
      } int sum = ;
      for (T1 t1 : a) {
      t1.join();
      sum+=t1.count;
      } t = System.currentTimeMillis() - t;
      System.out.println("执行时间: "+t);
      System.out.println("质数数量: "+sum);
      } static class T1 extends Thread{ int from;
      int to;
      int count; //最终结果,质数的数量 public T1(int from, int to) {
      if (from <= ) {
      count = ;
      from = ;
      } this.from = from;
      this.to = to;
      } @Override
      public void run() {
      // TODO Auto-generated method stub
      super.run(); for (int i = from; i < to; i++) {
      if (isPrime(i)) {
      count++;
      }
      } } // 是否是质数
      private boolean isPrime(int i) {
      double max = +Math.sqrt(i);
      for (int j = ; j < max; j++) {
      if (i%j == ) {
      return false;
      }
      } return true;
      } }
      }
    • Thread.yield();
      • 当前线程放弃时间片, 让出 cpu 资源
    • getPriority(),  setPriority();
      • 优先级, 1到10, 默认5
    • setDaemon(true);
      • 后台线程,守护线程
      • 一般所有前台线程结束,虚拟机自动退出
      • package day1702_线程;
        
        import java.text.SimpleDateFormat;
        import java.util.Date;
        import java.util.Scanner; public class Test3 {
        public static void main(String[] args) {
        T1 t1 = new T1();
        t1.start(); Thread t2 = new Thread() {
        @Override
        public void run() {
        // TODO Auto-generated method stub
        super.run(); System.out.println("按回车打断 t 线程");
        new Scanner(System.in).nextLine(); t1.interrupt(); // 打断
        }
        }; t2.setDaemon(true); // 设置后台线程
        t2.start();
        } static class T1 extends Thread{
        @Override
        public void run() {
        // TODO Auto-generated method stub
        super.run(); SimpleDateFormat sdf =
        new SimpleDateFormat("HH:ss:mm"); for (int i = ; i < ; i++) {
        String s = sdf.format(new Date());
        System.out.println(s); // 停一秒
        try {
        Thread.sleep();
        } catch (InterruptedException e) {
        // TODO Auto-generated catch block
        e.printStackTrace(); System.out.println("谁TMD桶我");
        break; }
        } }
        }
        }
  • 多线程的数据访问冲突
    • 多个线程, 共享访问数据
    • 一个线程访问到修改的一半的数据,称为 脏数据
  •  线程同步 synchronized
    • 多个线程,步调一致的执行
    • 让多个线程, 争夺同一个对象的  同步锁
    • 谁抢到谁执行, 抢不到等待
    • 同步锁
      • 任何对象, 都有一个唯一的同步锁
    • synchronized
      • 遇到同步关键字, 要先抢到锁才能执行,否则等待
    • synchronized(对象){  }
      • 争夺指定对象的锁
    • package day1702_线程;
      
      import java.util.Arrays;
      
      public class Test5 {
      
          static char[] a = {'-','-','-','-'};
      static char v = '*'; public static void main(String[] args) {
      new Thread() {
      @Override
      public void run() {
      // TODO Auto-generated method stub
      super.run(); while (true) { // 数组同步锁
      synchronized (a) {
      for (int i = ; i < a.length; i++) {
      a[i] = v;
      }
      v = (v=='*'?'-':'*');
      } }
      }
      }.start(); new Thread() {
      @Override
      public void run() {
      // TODO Auto-generated method stub
      super.run(); while (true) {
      // 数组同步锁
      synchronized (a) {
      System.out.println(Arrays.toString(a));
      } }
      }
      }.start();
      }
      }


    • synchronized void f() {  };
      • 抢当前对象的锁
    • package day1702_线程;
      
      public class Test6 {
      public static void main(String[] args) { R1 r1 = new R1(); Thread t1 = new Thread(r1);
      t1.start(); // main 线程死循环 ,检查 i 是否是奇数
      while (true) { int i = r1.get();
      if (i%==) {
      System.out.println(i);
      System.exit();// 关闭虚拟机 } }
      } static class R1 implements Runnable{ static int i; synchronized public void add(){
      i++;
      i++;
      } synchronized public int get() {
      return i;
      } @Override
      public void run() {
      // TODO Auto-generated method stub
      while (true) {
      add();
      }
      }
      }
      }


    • static synchronized void f() { };
      • 抢类的锁
    • package day1702_线程;
      
      public class Test6 {
      public static void main(String[] args) { R1 r1 = new R1();
      R1 r2 = new R1(); Thread t1 = new Thread(r1);
      t1.start(); Thread t2 = new Thread(r2);
      t2.start(); // main 线程死循环 ,检查 i 是否是奇数
      while (true) { int i = r2.get();
      if (i%==) {
      System.out.println(i);
      System.exit();// 关闭虚拟机 } }
      } static class R1 implements Runnable{ static int i; static synchronized public void add(){
      i++;
      i++;
      } static synchronized public int get() {
      return i;
      } @Override
      public void run() {
      // TODO Auto-generated method stub
      while (true) {
      add();
      }
      }
      }
      }


java - day017 - 线程的更多相关文章

  1. java之线程

    java之线程 一:线程: 线程是什么呢?线程,有时被称为轻量级进程是程序执行流的最小单元.一个标准的线程由线程ID,当前指令指针(PC),寄存器集合和堆栈组成.另外,线程是进程中的一个实体,是被系统 ...

  2. Java 使用线程方式Thread和Runnable,以及Thread与Runnable的区别

    一. java中实现线程的方式有Thread和Runnable Thread: public class Thread1 extends Thread{ @Override public void r ...

  3. Java的线程安全

    线程安全 我们这里讨论的线程安全,就限定于多个线程之间存在共享数据访问这个前提,因为如果一段代码根本不会与其他线程共享数据,那么从线程安全的角度来看,程序是串行执行还是多线程执行对它来说是完全没有区别 ...

  4. 深入理解Java之线程池

    原作者:海子 出处:http://www.cnblogs.com/dolphin0520/ 本文归作者海子和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则 ...

  5. java中线程分两种,守护线程和用户线程。

    java中线程分为两种类型:用户线程和守护线程. 通过Thread.setDaemon(false)设置为用户线程: 通过Thread.setDaemon(true)设置为守护线程. 如果不设置次属性 ...

  6. java 多线程—— 线程让步

    java 多线程 目录: Java 多线程——基础知识 Java 多线程 —— synchronized关键字 java 多线程——一个定时调度的例子 java 多线程——quartz 定时调度的例子 ...

  7. java 多线程—— 线程等待与唤醒

    java 多线程 目录: Java 多线程——基础知识 Java 多线程 —— synchronized关键字 java 多线程——一个定时调度的例子 java 多线程——quartz 定时调度的例子 ...

  8. Java的线程模型

    并发不一定要依赖多线程(如PHP中很常见的多进程并发),但是在Java里面谈论并发,大多数都与线程脱不开关系. 线程是比进程更轻量级的调度执行单位,线程的引入,可以把一个进程的资源分配和执行调度分开, ...

  9. Java多线程 - 线程状态

    转自: http://www.cnblogs.com/lwbqqyumidi/p/3804883.html 一.线程的生命周期及五种基本状态 关于Java中线程的生命周期,首先看一下下面这张较为经典的 ...

随机推荐

  1. LeetCode_258. Add Digits

    258. Add Digits Easy Given a non-negative integer num, repeatedly add all its digits until the resul ...

  2. DBGridEh中根据单价和数量如何计算金额?

    单价和数量输入完后,在数量单元格往任何方向移动(上下左右),金额都能自动计算.如何实现? 不要在UI元素的事件中计算字段,你可以在单价字段和数量字段的OnChange事件中进行计算.假设数据集名称为D ...

  3. Swift编码总结1

    1. fileprivate (set) var hasSetDiscount = false中fileprivate (set)表示什么意思: //设置setter私有,但是getter为publi ...

  4. 【PV和PVC】kubernetes存储 persistent volume(持久化硬盘)和 persistent volume claim(持久化硬盘请求)

    报错:pod has unbound immediate PersistentVolumeClaims (repeated 11 times) pv没有满足pvc需求 https://www.cnbl ...

  5. 静态站点生成器-md-vue-vuepress

    推荐指数:

  6. LODOP统计table自动分页后的每页的某列合计值

    LODOP中超文本会根据打印项高度或超过纸张,自动分页.(相关博文:Lodop打印控件 超文本自动分页.LODOP中ADD_PRINT_TABLE.HTM.HTML表格自动分页测试.Lodop打印表格 ...

  7. 【QT开发】信号转发器QSignalMapper的使用

    QSignalMapper我们可以将它理解为一个信号翻译器或者说是哥信号转发器.它的主要应用在于可以实现一个函数相应不同按钮的实现功能.比如我们 实现一个计算器的时候,很多不同的按钮都有着差不多的功能 ...

  8. php面相对象类中成员

    类中成员 一个类的内部可以有3种代码:属性.方法.类常量它们统称为“类中成员”. 一般属性 属性就是放在一个类中的变量. 定义形式: 形式1: var  $v1 ; //定义不赋值 形式2: var ...

  9. 1010 Radix:猥琐的测试数据

    谨以此题纪念边界测试数据浪费了我多少时间:https://pintia.cn/problem-sets/994805342720868352/problems/994805507225665536 # ...

  10. Windows上安装配置SSH教程(1)

    作者:feipeng8848 出处:https://www.cnblogs.com/feipeng8848/p/8559803.html 本站使用「署名 4.0 国际」创作共享协议,转载请在文章明显位 ...