当前时区为 UTC + 8 小时



发表新帖 回复这个主题  [ 5 篇帖子 ] 
作者 内容
1 楼 
 文章标题 : swap问题
帖子发表于 : 2007-04-26 20:59 

注册: 2007-03-19 16:44
帖子: 31
送出感谢: 0 次
接收感谢: 0 次
本人是一个新手,在这里混了几天看见论坛上有人说那个SWAP是在内存用完的时候才使用的,可我发现我的机器内存还有一半多的时候就开始使用SWAP了,希望知道的兄弟姐妹们指点一下。。。


页首
 用户资料  
 
2 楼 
 文章标题 :
帖子发表于 : 2007-04-26 21:01 

注册: 2007-03-19 16:44
帖子: 31
送出感谢: 0 次
接收感谢: 0 次
自己先顶一个


页首
 用户资料  
 
3 楼 
 文章标题 :
帖子发表于 : 2007-04-26 21:07 
头像

注册: 2007-02-11 13:27
帖子: 887
送出感谢: 0 次
接收感谢: 0 次
我的也是这样
我猜想可能是开始内存被某些程序占据了然后新开的程序使用SWAP
然后某些占用内存的程序退出后就留下了剩余的内存
不知道对不对
高手来个解答~~


页首
 用户资料  
 
4 楼 
 文章标题 :
帖子发表于 : 2007-04-26 22:47 
头像

注册: 2006-10-31 14:49
帖子: 1617
送出感谢: 0 次
接收感谢: 0 次
这个问题比较复杂,不好全面回答
虚拟内存是为了增大物理内存的空间而设计,虚拟内存的段页式管理是一种很优秀的管理。
能让编程人员很有效的利用内存,能执行很大的程序,我们不需要把整个程序都放到内存中,例如:
1,程序通常会处理异常错误条件的代码,但是这种情况很少发生,这样的代码几乎是不执行的
2,比如数组,链表通常会分配比实际需要的更多的内存,声明1000*1000元的数组,可能实际用的只有10*10的元素,汇编就更是如此了
3,有些程序的某些选项会或特点可能会很少用到
于是这些代码一般会被放到虚拟内存中,有很多好处:
1,程序不再受现有的物理内存的限制。用户可以为一个巨大的虚拟地址空间写程序,简化编程操作
2,每个用户程序使用了更少的物理内存,这样就使得更多的程序可以同时执行,CPU的使用率会增加,而响应的时间或周转时间并不增加
3,由于装入或交换每个用户程序到内存中所需的I/O会更少,用户程序会运行的更快
这样产生了虚拟内存应用技术。将用户逻辑内存和物理内存分开,能极大的扩展编程人员的俄编程空间,减小非系统级编程人员的编程压力。
但是也要看到,虚拟内存的实现并不容易,如果使用不当还会大大的降低性能。一个不是偏见的例子,windows过于依赖于虚拟内存,导致在大程序的运行初始化和退出的时候,物理内存和虚拟内存的页面交换会使系统变慢甚至死机。linux在这方面学习了unix的优秀内存管理规则,在尽量使用物理内存的情况下,加快系统的响应。这个源自于UNIX的诞生,效率重于性能。虚拟内存的页面一般申请之后会被保留用于其他程序二次使用。
也不能说linux就一定在内存管理方面绝对很好很好,有时候也会有内存溢出,这种崩溃的几率还是有的

有兴趣的话看一下操作系统的书,会更对操作系统有个新的认识


页首
 用户资料  
 
5 楼 
 文章标题 :
帖子发表于 : 2007-04-26 22:50 
头像

注册: 2007-02-11 13:27
帖子: 887
送出感谢: 0 次
接收感谢: 0 次
LS真够专业
赞一个!


页首
 用户资料  
 
显示帖子 :  排序  
发表新帖 回复这个主题  [ 5 篇帖子 ] 

当前时区为 UTC + 8 小时


在线用户

正在浏览此版面的用户:没有注册用户 和 4 位游客


不能 在这个版面发表主题
不能 在这个版面回复主题
不能 在这个版面编辑帖子
不能 在这个版面删除帖子
不能 在这个版面提交附件

前往 :  
本站点为公益性站点,用于推广开源自由软件,由 DiaHosting VPSBudgetVM VPS 提供服务。
我们认为:软件应可免费取得,软件工具在各种语言环境下皆可使用,且不会有任何功能上的差异;
人们应有定制和修改软件的自由,且方式不受限制,只要他们自认为合适。

Powered by phpBB © 2000, 2002, 2005, 2007 phpBB Group
简体中文语系由 王笑宇 翻译