Java多线程精讲(非高并发-授课专用)附synchronized(一)

简介: Java多线程精讲(非高并发-授课专用)附synchronized

Java多线程精讲(非高并发-授课专用)

目录


程序,进程,线程的基本概念


start与run的区别


函数测试demo:


创建线程(一)【new Thread()】


创建线程(二)【extends Thread】


创建线程(三)【implements Runnable】


线程无交互测试:【run】


线程无交互测试:【start】


加强交互:【加上sleep休息时间】


游戏编写:【王语嫣大战表哥·慕容复】


synchronized


程序,进程,线程的基本概念

程序:是为完成特定任务,用某种语言编写的一组指令的集合,即指一段静态的代码,静态对象。

进程:是程序的一次执行过程,或是正在运行的一个程序,是一个动态的过程,有它自身的产生,存在和消亡的过程。——生命周期。

线程:进程可进一步细化为线程,是一个程序内部的一条执行路径。


即:线程《线程(一个程序可以有多个线程)

程序:静态的代码 进程:动态执行的程序

线程:进程中要同时干几件事时,每一件事的执行路径成为线程。


附:


并行:多个CPU同时执行多个任务,比如:多个人同时做不同的事。


并发:一个CPU(采用时间片)同时执行多个任务,比如秒杀平台,多个人做同件事

18.png



线程的相关API

//获取当前线程的名字
currentThread();静态方法,返回执行当前代码的线程
Thread.currentThread().getName();获取当前线程的名字
Thread.currentThread().setName();设置当前线程的名字
sleep(long millitime);线程休眠一段时间
start();1.启动当前线程2.调用线程中的run方法
run();通常需要重写Thread类中的此方法,将创建的线程要执行的操作声明在此方法中
join();线程等待·卡死的等待。
isAlive();判断当前线程是否存活


start与run的区别

用start方法来启动线程,真正实现了多线程运行,这时无需等待run方法体代码执行完毕而直接继续执行下面的代码。通过调用Thread类的start()方法来启动一个线程,这时此线程处于就绪(可运行)状态,并没有运行,一旦得到cpu时间片,就开始执行run()方法,这里方法run()称为线程体,它包含了要执行的这个线程的内容,run方法运行结束,此线程随即终止。


函数测试demo:

package test;
/**
 * 
 * @author laoshifu
 * @date 2021年12月5日
 *
 */
public class Main {
  public static void main(String[] args) throws InterruptedException {
    //修改线程名城
    Thread.currentThread().setName("superMan");
    //获取线程名称
    String name = Thread.currentThread().getName();
    System.out.println(name);
    //当前线程是否存在
    boolean b = Thread.currentThread().isAlive();
    System.out.println(b);
    //创建多线程
    Thread t = new Thread() {
      @Override
      public void run() {
        for (int i = 0; i < 100; i++) {
          System.out.println(i);
        }
      }
    };
    //启动多线程
    t.run();
    //线程等待
    Thread.currentThread().join();
    //休息
    Thread.sleep(2000);
    //某线程是否存在
    System.out.println(t.isAlive());
  }
}


创建线程(一)【new Thread()】

这里继承Thread类的方法是比较常用的一种,如果说你只是想起一条线程。没有什么其它特殊的要求,那么可以使用Thread

//创建多线程
    Thread t = new Thread() {
      @Override
      public void run() {
        for (int i = 0; i < 100; i++) {
          System.out.println(i);
        }
      }
    };
    //启动多线程
    t.run();


创建线程(二)【extends Thread】

19.png

package test;
public class Thread_test extends Thread{
  @Override
  public void run() {
    currentThread().setName("orange");
    for (int i = 0; i < 100; i++) {
      System.out.println(currentThread().getName()+":"+i);
    }
  }
}
package test;
/**
 * @author laoshifu
 * @date 2021年12月5日
 */
public class Main {
  public static void main(String[] args) {
    Thread_test test = new Thread_test();
    test.run();
  }
}
}

20.png

创建线程(三)【implements Runnable】

采用Runnable也是非常常见的一种,我们只需要重写run方法即可。下面也来看个实例。

package test;
public class Thread_te implements Runnable{
  @Override
  public void run() {
    for (int i = 0; i < 100; i++) {
      System.out.println("Runnable"+":"+i);
    }
  }
}
package test;
/**
 * @author laoshifu
 * @date 2021年12月5日
 */
public class Main {
  public static void main(String[] args) {
    Thread t1 = new Thread(new Thread_te());
    t1.start();
  }
}}

21.png

如果一个类继承Thread,则不适合资源共享。但是如果实现了Runable接口的话,则很容易的实现资源共享。


线程无交互测试:【run】

package test;
/**
 * @author laoshifu
 * @date 2021年12月5日
 */
public class Main {
  public static void main(String[] args) {
    Thread_test test = new Thread_test();
    test.run();
    Thread_test2 test2 = new Thread_test2();
    test2.run();
    Thread t3 = new Thread(new Thread_te());
    t3.start();
  }
}


无交互

22.png



线程无交互测试:【start】

package test;
/**
 * @author laoshifu
 * @date 2021年12月5日
 */
public class Main {
  public static void main(String[] args) {
    Thread_test test = new Thread_test();
    Thread_test2 test2 = new Thread_test2();
    Thread t3 = new Thread(new Thread_te());
    System.out.println("开启一");
    test.start();
    System.out.println("开启二");
    test2.start();
    System.out.println("开启三");
    t3.start();
  }
}

23.png

加强交互:【加上sleep休息时间】

24.png

总结:


实现Runnable接口比继承Thread类所具有的优势:


1):适合多个相同的程序代码的线程去处理同一个资源

2):可以避免java中的单继承的限制

3):增加程序的健壮性,代码可以被多个线程共享,代码和数据独立

相关文章
|
7天前
|
JSON 网络协议 安全
【Java】(10)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
51 1
|
7天前
|
JSON 网络协议 安全
【Java基础】(1)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
42 1
|
29天前
|
数据采集 存储 弹性计算
高并发Java爬虫的瓶颈分析与动态线程优化方案
高并发Java爬虫的瓶颈分析与动态线程优化方案
Java 数据库 Spring
71 0
|
1月前
|
算法 Java
Java多线程编程:实现线程间数据共享机制
以上就是Java中几种主要处理多线程序列化资源以及协调各自独立运行但需相互配合以完成任务threads 的技术手段与策略。正确应用上述技术将大大增强你程序稳定性与效率同时也降低bug出现率因此深刻理解每项技术背后理论至关重要.
114 16
|
2月前
|
缓存 并行计算 安全
关于Java多线程详解
本文深入讲解Java多线程编程,涵盖基础概念、线程创建与管理、同步机制、并发工具类、线程池、线程安全集合、实战案例及常见问题解决方案,助你掌握高性能并发编程技巧,应对多线程开发中的挑战。
|
2月前
|
数据采集 存储 前端开发
Java爬虫性能优化:多线程抓取JSP动态数据实践
Java爬虫性能优化:多线程抓取JSP动态数据实践
|
3月前
|
缓存 NoSQL Java
Java 项目实操高并发电商系统核心模块实现从基础到进阶的长尾技术要点详解 Java 项目实操
本项目实战实现高并发电商系统核心模块,涵盖商品、订单与库存服务。采用Spring Boot 3、Redis 7、RabbitMQ等最新技术栈,通过秒杀场景解决库存超卖、限流熔断及分布式事务难题。结合多级缓存优化查询性能,提升系统稳定性与吞吐能力,适用于Java微服务开发进阶学习。
119 0
|
3月前
|
Java API 调度
从阻塞到畅通:Java虚拟线程开启并发新纪元
从阻塞到畅通:Java虚拟线程开启并发新纪元
319 83
|
3月前
|
安全 算法 Java
Java 中 synchronized 与 AtomicInteger 的区别
在Java多线程编程中,`synchronized`和`AtomicInteger`均用于实现线程安全,但原理与适用场景不同。`synchronized`是基于对象锁的同步机制,适用于复杂逻辑和多变量同步,如银行转账;而`AtomicInteger`采用CAS算法,适合单一变量的原子操作,例如计数器更新。二者各有优劣,应根据具体需求选择使用。
102 0

热门文章

最新文章