Това е въпрос, който се отнася до всеки, който се е влюбил в преносими приложения: защо не всичко приложения преносими?
Днешната сесия за въпроси и отговори се отнася до нас с любезното съдействие на SuperUser - подразделение на Stack Exchange, обединяване на уеб сайтове с въпроси и отговори.
Въпроса
Reader на SuperUser Том обича преносимите приложения на чистата организация и иска да знае защо всичко не е преносимо:
I’ve recently been trying to ‘install’ stuff a lot less on my Windows machine (I hate installers – I need to know where programs put stuff…), choosing to use portable or standalone versions of applications instead.
I put them all in a ‘Programs’ dir on a drive separate from my Windows partition, so whenever I reinstall, I have all my applications available with minimal effort and on the plus side, I get a nice clean setup.
Applications like Office and Creative Suite still require me to go through a horribly long installation process where a thousand random libraries and tools are thrown across my system.
Why do Windows apps still need installing? Why can’t we just drag Photoshop to a folder à la OSX and just have it work? Does anyone else focus on portable apps, or am I just being OCD about the whole thing?
Ние със сигурност сме фенове на преносими приложения и бихме искали да стигнем до дъното на нещата.
Отговорът
Сътрудникът на SuperUser Дейвид Уитни предлага известно разбиране за това защо много приложения не са преносими и как Windows налага някакво споразумение за преносимост:
Installers are a result of years of evolution and a little bit of (simplified) history helps understand why they do what they do..
The Windows 3.1 model suggested config.ini style configuration files per application with supporting shared libaries going into system folders to prevent duplication and wasted disk space.
Windows 95 introduced the registry allowing a central store for application configuration replacing many configuration files. More importantly, windows configuration was stored in the same place.
The registry became bloated due to applications not cleaning up after themselves. DLL hell happened as a result of multiple versions of the same shared libraries overwriting each other.
.NET introduced the concept of app.config (almost ini files mark 2, this time with a little more structure saving developers wasting time writing manual parsers). The GAC was introduced to version shared assemblies in an attempt to prevent DLL Hell.
In Windows XP and moreso in Vista, Microsoft attempted to define the userspace as a place to store user data and configuration files in a single standard location to allow for roamning profiles and easy migration (just copy your profile) with the applications installed in Program Files.
So I guess, the reason is that “applications in Windows are designed to live in one place, their shared dependencies in another, and the user specific data in another”, which pretty much works against the concept of xcopying a single location.
.. and that’s before you have to configure user accounts, and setup and ensure security permissions, and download updates, and install windows services…
xcopy is the “simple case” and certainly isn’t a best fit for everything.
За съжаление за феновете на всички неща преносими, много приложения - особено големи приложения като Office - ще останат твърдо фиксирани към и разпределени в операционната система.
Имате ли нещо, което да добавите към обяснението? Звучи в коментарите. Искате ли да прочетете повече отговори от други потребители на Stack Exchange? Вижте цялата тема на дискусията тук.