进程:同一个操作系统中执行的一个子程序,包含了三部分虚拟CPU、代码、数据。
多进程:同一个操作系统中执行的多个并行的子程序。可以提高CPU的使用率。
线程:在同一个进程中执行的子程序流。
多线程:同一进程中并发执行的多个子程序流。可以提高CPU的使用率。
进程与线程的区别:
进程有独立的进程空间,进程中的数据存放空间(堆空间和栈空间)是独立的。
线程的堆空间是共享的,栈空间是独立的,线程消耗的资源也比进程小,相互之间可以影响的。
![fa50ec169fa394eb4d2d1a9ebdb0dd66.png](https://i-blog.csdnimg.cn/blog_migrate/6e533fe3ad2ec53cd11c16386c3d14ce.jpeg)
Java中如何调进程:
调用本地程序的两个类:
Runtime
Runtime.getRuntime.exec(...);//执行一个程序
其返回值就是Process类型
注意:
只有运行状态的线程才有机会执行代码,主线程的中止不会影响其他正在运行中的线程,主线程中止也就是main方法退出了,只有进程中的所有线程都中止时,进程(JVM进程)才会退出,只要有线程没有中止,进程就不会退出。
操作系统决定线程是否有优先级,独立式的操作系统中系统会有优先级的概念,共享式的操作系统则不会有优先级的。
在线程的内部,程序依然顺序执行。