Віртуальної пам’яті є більше, ніж просто «програми, що виділяють оперативну пам’ять, і коли фізична оперативна пам’ять закінчується, SWAP щось переходить на екран».
У Linux (і, можливо, UNIX взагалі), система намагається тримати сторінки, прочитані нещодавно в оперативній пам'яті: програми виконані, завантажені дані, дані, написані нещодавно (вже на диску) і т. Д. Так що, якщо та сама програма знову буде виконуватися, вона не буде Вам не доведеться перезавантажуватися з диска. Коли якась програма вимагає виділити більше пам’яті для її віртуального адресного простору, спочатку залишені дискові буфери переназначаються (без доступу до диску). Якщо цього недостатньо, деякі сторінки запущених додатків, до яких недавно не можна було отримати доступ, фактично заміняються. В Linux заміни зазвичай не бувають взагалі. Як тільки ваша система починає мінятись, ви помічаєте посилену активність приводу (і млявість), і ви переходите "ой, що ж ..", тому що це, ймовірно, означає, що якесь додаток просочується пам'яттю, або щось під кришкою почало нереститися поза контролем.
Традиційно у Windows є дурна додаткова звичка: вони через деякий час очікують на те, що вони заміняють цілі програми для користувальницького простору. Суворо, без помилування, просто щоб було доступно якомога більше оперативної пам’яті, «про всяк випадок» ви хотіли запустити ще одне голодне додаток. Якщо ви залишите ваш комп'ютер працює, і ви підете на кілька годин, після повернення ви помітите, що будь-яке додаток, до якого ви переходите, воно завантажиться плавно за допомогою swap. Така поведінка була особливо болісною в Windows 2000 і стає поступово менш помітною у сучасних версіях Windows. У W2k вимкнення swap не вимагало. Windows 7 все ще може блукати, як мед, іноді без особливих причин, Windows 8.1 і 10 помітно покращилися ... але все ще немає налаштованої ручки для "заміщення" чи інших налаштованих параметрів алгоритму заміни.
Існують і інші фактори, які можуть призвести до подрібнення системи по повільному доступу до диска. У Windows 7 ви ніколи не знаєте, чи система просто замінила ваш додаток за старим хорошим способом W2k, чи ви повинні звинувачувати антивірус у тому, що ваш додаток запускається так повільно, або якщо оновлення Windows робить щось у програмі фон цього часу (як відомо, що в його алгоритмах є зворотні звороти, що призводять до зависань зі 100% споживанням процесора та / або обстрілу диска), або, якщо конкретно, якесь завдання .служби .NET Framework загубилося в базі даних WinSXS чи що. Часом / у деяких версіях / втіленнях програмного забезпечення Майкрософт, насправді здається, що деякі вікна "у фонових завданнях" (зокрема, управління локальною базою даних Windows Update) свідомо "затушовуються" в диспетчері завдань, їх використання процесора та оперативної пам’яті не відображається в загальному споживанні пам'яті. "Законна" діяльність, але її досить важко відрізнити від зловмисного корінгового програмного забезпечення ... Лише після того, як треска припиняється, і миттєво з'являється повітряна куля, що говорить "нові оновлення", ви знаєте, в чому причина.
Принаймні, останні версії Windows можуть повідомити вам про дію вводу-виводу на кожен процес, а про окремі сервіси тепер повідомляється окремо (замість одного процесу SVCHOST.EXE).