进程与线程

概念:

      进程是计算机上正在执行的一个独立的应用程序,进程是一个动态概念,必须是进行状态。如果一个应用程序没有启动,那就不是进程:进程是资源的分配的基本单位(内存、进程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方法会阻塞当前线程),可以了解子线程的执行情况,可以取消任务的执行。
原文地址:https://www.cnblogs.com/128-cdy/p/12454855.html