zoukankan      html  css  js  c++  java
  • 进程与线程

    概念:

          进程是计算机上正在执行的一个独立的应用程序,进程是一个动态概念,必须是进行状态。如果一个应用程序没有启动,那就不是进程:进程是资源的分配的基本单位(内存、进程ID(PID))。

          线程是组成进程的基本单位,可以完成特定的功能,一个进程是有一个或者多个线程组成的,线程是资源调度的单位。

    区别:

          进程是有独立的内存空间,每个进程之间是相互独立的,互不干扰;线程有共享的内存空间(也有私有的)。

          进程是相互独立的,一个进程的奔溃不会影响到其他的进程,进程是安全的;线程存在内存空间的共享,一个线程的奔溃可能会影响到其他的线程的执行,线程的安全性不如进程。

    关系:进程是相互独立的,一个进程下可以有一个或者多个线程

    Java默认的线程:

    • Main方法启动会对应启动一个JVM实例,main也是Java的一个进程,也叫做主线程
    • Java默认是有两个线程:主线程和垃圾回收的线程(Main和GC)

    Java本身能否启动线程?

     start()方法来启动并创建出新线程:底层调用native的start0()方法

    图片.png

    Java本身是没办法启动线程的,线启动时需要底层操作系统支持的,Java通过调用本地方法,C++编写的动态函数库,由C++去操作底层启动线程,Java是通过间接的调用来启动线程。

    线程的创建:

    • 继承Thread+重写run()方法
    • 实现Runable接口+重写run()方法   (推荐,避免单继承的局限性)
    • 实现Callable接口

    Runnable是任务,Thread类是线程对象,线程是用来执行任务。

    Callable:接口提供了call方法,具有范围值,通过泛型来定义,该接口可以抛出异常,FutureTask类是继承Runable接口,即FutureTask是Runable接口的实现类,而FutureTask类提供了构造函数FutureTask(Callable<V> callable),可以接受Callable类型的任务

    Runable接口和Callable接口区别:

    1. Callable接口规定的方法是call()方法,Runnable接口规定的方式是run()方法
    2. Callable的任务执行后有返回值,而Runable的任务不能有返回值
    3. call()方法可抛出异常,run()方法不能抛出异常
    4. 通过运行Callable的实例可以获取到FutureTask对象,FutureTask对象表示异步执行的结果,他提供了get方法可以异步获取线程执行的结果(get方法会阻塞当前线程),可以了解子线程的执行情况,可以取消任务的执行。
  • 相关阅读:
    最小圆覆盖
    BZOJ3572 [Hnoi2014]世界树 【虚树 + 树形dp】
    一些组合数学
    BZOJ3611 [Heoi2014]大工程 【虚树】
    线段树合并
    BZOJ4446 [Scoi2015]小凸玩密室 【树形Dp】
    生成函数小记
    BZOJ2337 [HNOI2011]XOR和路径 【概率dp + 高斯消元】
    连续数字异或和
    POJ2976:Dropping tests——题解
  • 原文地址:https://www.cnblogs.com/128-cdy/p/12454855.html
Copyright © 2011-2022 走看看