开发者社区> 问答> 正文

有几百个进程却只有几G的内存,求解释这几百个进程如何共享内存的?

有几百个进程却只有几G的内存,求解释这几百个进程如何共享内存的?

展开
收起
我的中国 2017-11-30 18:48:15 1971 0
2 条回答
写回答
取消 提交回答
  • 啥也不干的进程基本不占什么内存。光创立一个进程这事本身占用的内存是很少的

    2019-07-17 21:46:45
    赞同 展开评论 打赏
  • R&S网络资深工程师 ,阿里云论坛官方版主,阿里云云计算ACP,春考教学网站长,IT技术晋级之路专辑作者

    进程分配的内存实际是虚拟内存,实际的物理内存不会立即分配,物理内存仅在访问时通过缺页异常分配,所以所有进程的占用虚拟内存总和是可以超过物理内存的,但物理内存总和不行。top命令结果中,VIRT和RES分别代表虚拟内存和物理内存使用量。
    关于调度,cpu分时复用,按一定的算法给每个进程分配时间片,简单说,就是每个进程间隔运行一小段时间,由于时间片粒度小(通常ms级别),所以用户和上次业务通常感知不明显。

    同一个物理页可以映射到不同进程的地址空间,比如如果多个版本的程序都用同一个Visual C++运行时的DLL,那么只读数据是共享的。一个进程的私有内存才是说占就真占的。

    另外,系统会把暂时不用的内存(比如窗口正在被最小化的程序的内存)交换到磁盘上的虚拟内存交换文件,直到下次程序想起来用(比如窗口正在被还原)的时候再交换回来。一个机器上的可用内存应该是对操作系统可见的物理内存(32位的Windows因为地址空间限制一些内存可能用不了)+虚拟内存。

    2019-07-17 21:46:45
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
服务上云加速大家居产业C2M进程 立即下载
内存取证与IaaS云平台恶意行 为的安全监控 立即下载
云服务器ECS内存增强型实例re6全新发布 立即下载

相关实验场景

更多