库调多了 都忘了最基础的概念 - 进程 / 线程篇

简介: 库调多了 都忘了最基础的概念 - 进程 / 线程篇

🍁 作者:知识浅谈,CSDN博客专家,阿里云签约博主,InfoQ签约博主,华为云云享专家

📌 擅长领域:全栈工程师、爬虫、ACM算法

💒 公众号:知识浅谈

🔥 联系方式vx:zsqtcc

温馨提醒:此文涉嫌过度分享干货,请仔细阅读

🤞这次都给他拿下🤞

正菜来了⛳⛳⛳

🎈进程和线程有什么区别?

进程:进程是一个程序的运行,是资源的分配单位,如:QQ的运行。

线程:线程是一串指令码在cpu的运行,是cpu的调度单位。

  1. 进程具有自己的资源,线程占用的是进程的资源。
  2. 进程的上下文切换比较复杂,线程的上下文切换较为容易,因为进程切换要涉及虚拟地址空间的切换,而线程不涉及。
  3. 进程的通信:管道,队列,信号量,线程的通信:共享内存,如Object的wait notify,重入锁,semophone信号量,counntdown。

🎈有哪些创建线程的方法?推荐使用哪种?

  1. 通过继承Thread的方式创建线程
    重写run方法,
    调用start()方法开启一线程并执行
  2. 实现Runnable方法
    重写run方法,创建一个子类对象
    传递给Thread的对象,并调用start运行。
  3. 实现callable方法
    重写call方法,创建一个子类对象,并作为FutureTask的参数传入
    然后把创建的FutureTask作为参数传递给Thread的对象,并调用start运行。
class A implements Callable<String> {
    @Override
    public String call() throws Exception {
        return "run";
    }
}
public class Main {
    public static void main(String[] args) throws ExecutionException, InterruptedException {
        A a = new A();
        FutureTask<String> vFutureTask = new FutureTask<>(a);
        Thread thread = new Thread(vFutureTask);
        thread.start();
        System.out.println(vFutureTask.get());
    }
}
  1. 使用线程池
    ExecutorService pools = Executors.newFixedThreadPool();
    pool.submit(实现run方法)

🎈为什么start方法不能重复调用?而run方法却可以?

首先start和run的区别,调用start的时候会先创建一个线程,然后在创建的线程中执行run方法,而直接调用run相当于在当前线程中执行run方法,并没有创建线程之后执行。

因为run方法是普通方法,start方法是线程创建的方法,普通方法可以执行多次,但是线程只能创建一次,所以start方法只能调用1次。

🎈说一下线程生命周期,以及转换过程?

线程的生命周期状态:New,Runable,Waiting,TimeWaiting,Blocked,Terminated

转换过程:

  1. 首先new之后,状态为New
  2. 调用start之后状态为Runnable
  3. 调用wait() join()之后状态为Waiting
  4. 调用wait(time),sleep(time) 之后状态为TimeWaiting
  5. Block这个转台比较特殊,是因为争夺monitor锁阻塞的状态
    如刚开始synchronized获取锁之后,调用wait()释放锁,然后又被其他线程调用notify()唤醒,但是此刻锁被其他线程占用,当前被唤醒的线程就是Blocked状态
  6. 线程执行结束之后的状态为Terminated

🎈为什么wait和notify必须放在synchronized中?

wait:因为wait是用来释放锁的,释放锁之前当前线程需要先获取锁。

notify:这个是用来唤醒waitset中的线程,你要唤醒别人,首先自己得有锁并且将要结束,采取唤醒别人。

所以两个都需要在有锁的状态下进行,而synchronized就是用来获取锁的

🎈sleep方法和wait方法有什么区别?

老生常谈了。

从几个方面来说吧

  1. sleep属于关键字,wait属于API
  2. sleep是Thread中的方法,而wait是Object中的方法
  3. sleep可以在任何代码中执行,但是wait只能在同步代码块中执行
  4. sleep按照规定的时间唤醒,但是wait可以使用notify,notifyall唤醒还可以设置时间自动唤醒
  5. 两个都可被interrrupt中断

🎈如何正确停止线程?

像之前的stop() suspend()这两种停止线程和悬挂线程都是弃用的状态,因为这两个是强制暂停和挂起线程的,如果其他线程要等待强制停止和挂起的线程的结果,像这种直接断掉,就一直等不到结果就会出现问题。

我们使用interrrupt()方法来中断,当然不是真正的中断,是把线程中断标志置为true,然后在要停止的线程中去查看中断标志,如果为true就结束线程。

这里有个主义的点就是,interrupt(),interrupted(),isInterrupted()

  • interrupt():表示用来把中断标志置为true
  • interrupted():表示用来查看中断标志并抹去中断标志就是变为false
  • isInterrupted() :表示用来查看中断标志但不抹去中断标志

🍚总结

相关文章
|
4天前
|
存储 消息中间件 资源调度
「offer来了」进程线程有啥关系?10个知识点带你巩固操作系统基础知识
该文章总结了操作系统基础知识中的十个关键知识点,涵盖了进程与线程的概念及区别、进程间通信方式、线程同步机制、死锁现象及其预防方法、进程状态等内容,并通过具体实例帮助理解这些概念。
「offer来了」进程线程有啥关系?10个知识点带你巩固操作系统基础知识
|
3天前
|
资源调度 算法 调度
深入浅出操作系统之进程与线程管理
【9月更文挑战第29天】在数字世界的庞大舞台上,操作系统扮演着不可或缺的角色,它如同一位精通多门艺术的导演,精心指挥着每一个进程和线程的演出。本文将通过浅显的语言,带你走进操作系统的内心世界,探索进程和线程的管理奥秘,让你对这位幕后英雄有更深的了解。
|
7天前
|
Java
直接拿来用:进程&进程池&线程&线程池
直接拿来用:进程&进程池&线程&线程池
|
8天前
|
负载均衡 Java 调度
探索Python的并发编程:线程与进程的比较与应用
本文旨在深入探讨Python中的并发编程,重点比较线程与进程的异同、适用场景及实现方法。通过分析GIL对线程并发的影响,以及进程间通信的成本,我们将揭示何时选择线程或进程更为合理。同时,文章将提供实用的代码示例,帮助读者更好地理解并运用这些概念,以提升多任务处理的效率和性能。
|
18天前
|
开发者 Python
深入浅出操作系统:进程与线程的奥秘
【8月更文挑战第46天】在数字世界的幕后,操作系统扮演着至关重要的角色。本文将揭开进程与线程这两个核心概念的神秘面纱,通过生动的比喻和实际代码示例,带领读者理解它们的定义、区别以及如何在编程中运用这些知识来优化软件的性能。无论你是初学者还是有一定经验的开发者,这篇文章都将为你提供新的视角和实用技巧。
|
2天前
|
数据采集 消息中间件 并行计算
进程、线程与协程:并发执行的三种重要概念与应用
进程、线程与协程:并发执行的三种重要概念与应用
11 0
|
2天前
|
数据采集 Linux 调度
Python之多线程与多进程
Python之多线程与多进程
|
25天前
|
存储 Java 数据处理
进程中的线程调度
进程是应用程序运行的基本单位,包括主线程、用户线程和守护线程。计算机由存储器和处理器协同操作,操作系统设计为分时和分任务模式。在个人PC普及后,基于用户的时间片异步任务操作系统确保了更好的体验和性能。线程作为进程的调度单元,通过覆写`Thread`类的`run`方法来处理任务数据,并由系统调度框架统一管理。微服务架构进一步将应用分解为多个子服务,在不同节点上执行,提高数据处理效率与容错性,特别是在大规模数据存储和处理中表现显著。例如,利用微服务框架可以优化算法,加速业务逻辑处理,并在不同区块间分配海量数据存储任务。
|
7天前
|
存储 算法 Java
关于python3的一些理解(装饰器、垃圾回收、进程线程协程、全局解释器锁等)
该文章深入探讨了Python3中的多个重要概念,包括装饰器的工作原理、垃圾回收机制、进程与线程的区别及全局解释器锁(GIL)的影响等,并提供了详细的解释与示例代码。
15 0
|
10天前
|
并行计算 API 调度
探索Python中的并发编程:线程与进程的对比分析
【9月更文挑战第21天】本文深入探讨了Python中并发编程的核心概念,通过直观的代码示例和清晰的逻辑推理,引导读者理解线程与进程在解决并发问题时的不同应用场景。我们将从基础理论出发,逐步过渡到实际案例分析,旨在揭示Python并发模型的内在机制,并比较它们在执行效率、资源占用和适用场景方面的差异。文章不仅适合初学者构建并发编程的基础认识,同时也为有经验的开发者提供深度思考的视角。

热门文章

最新文章

下一篇
无影云桌面