一、概述
1、进程:同一个操作系统中,执行的子程序;包含3部分:CPU,代码,数据;如下图所示,每一行都是一个进程;例如WeChar(微信),mysqld.exe等;
2、多进程:同一个操作系统中,可执行的多个子程序;可以提高cpu的使用率;例如,我们在上图可以看到微信的图标有两个,一个是WeChar(32位),一个是Tencent Browsing Service(3…,这两个都是微信桌面程序,而Tecent Browsing Service是在微信这个程序里面的子进程,用来打开微信中的链接地址的一个浏览器;
3、多线程:我们知道Java支持多线程技术,但是Java的多线程,在这个【任务管理器】里是看不到的,我们怎么理解多进程和多线程呢,你可以理解为进程是完成某一部分业务功能的小组;例如一个超市系统,他有收银进程;导购进程;供应进程;然后他的收银是多线程的,好多个收银台能同时工作;
区别:
1、进程有独立的进程空间,进程中的数据存放在堆栈的空间是独立的;这个打个比方就是,每个国家就是一个独立的进程;国家内的领土主权是独立和完整的;而国家内的经济部,组织部,公共卫生部门就是每一个线程;线程的堆空间是共享的,就像你可以在上海设立上海市税务局,我也可以在上海这个堆空间里设立医院,组织部也可以在上海这个地方(可以理解为堆空间)设立组织部;但是栈的意思从翻译过来的角度说就是说(明修栈道暗度陈仓,栈是指的用木头隔开的通道或建筑,意在窄,小,浅,有点自私的味道在里面),线程不是用砖头做的,使用木头做的,所以消耗的资源小,而且私密性不是特别大,木头间会有缝隙,会透光,会渗水,互相叫喊能听得见,隔音效果也不是很好(这也是其优点之一);
我们再Java中获取进程的方式如下:
测试代码:利用Java调用cmd命令,获取进程的总内存,剩余内存和最大内存;
import org.junit.jupiter.api.Test;
import java.io.IOException;
public class TestRunTime {
/**
* test process
*/
@Test
public void testRunTime() throws IOException {
String [] cmd={"C:/Windows/System32/cmd.exe","/C","calc"};
Process runtime = Runtime.getRuntime().exec(cmd);
int i = 0;
while(i<10){
i++;
long totalMemory = Runtime.getRuntime().totalMemory();//总内存
long freeMemory = Runtime.getRuntime().freeMemory();//剩余内存
long maxMemory = Runtime.getRuntime().maxMemory();//最大内存
System.out.println("=========开始打印内存信息,第{"+i+"}次======");
System.out.println(totalMemory/1024/1024/1024.00+"G");
System.out.println(freeMemory/1024/1024/1024.00+"G");
System.out.println(maxMemory/1024/1024/1024.00+"G");
}
}
}