Suppose you have a small horde of programs you want to uninstall on your Windows system, but Windows will only let you uninstall them one at a time. Why is that? What is stopping you from uninstalling multiple programs simultaneously?
Today’s Question & Answer session comes to us courtesy of SuperUser—a subdivision of Stack Exchange, a community-driven grouping of Q&A web sites.
The Question
SuperUser reader Jeroen Bollen wants to know why a person is unable to uninstall multiple programs simultaneously in Windows:
What is it that stops people from uninstalling multiple programs simultaneously in Windows?
I do not want to uninstall multiple programs simultaneously, I am simply looking for the reason(s) why it would not be an option.
The Answer
SuperUser contributors ultrasawblade and techie007 have the answer for us. First up, ultrasawblade:
Followed by the answer from techie007:
There is always the question in designing any database – do you want speed or accuracy/safety? Given that installers can modify a system’s configuration and that a mishap could render the system inoperable, safety has been given a priority over speed.
One of the reasons why .msi installers are so slow is because rollback files are made for each file, etc. that will be modified, then deleted afterwards, allowing any changes to be “rolled back” if something goes wrong in the middle of things (such as a power outage or system crash).
Now, I believe the MSI engine itself enforces installing, modifying, or removing only one program at a time. If you try to run an .msi file while another is uninstalling for example, it will either not run, or will wait for the currently running uninstall process to finish. Non-MSI installers may not behave this way since they do not use the MSI engine. But because of this safety design decision, this is probably why appwiz.cpl insists on letting only one uninstaller be called at once.
CCleaner allows you to kick off uninstallers without waiting for previously running ones to finish, but MSI installers will likely still not work in parallel due to the above.
Have something to add to the explanation? Sound off in the comments. Want to read more answers from other tech-savvy Stack Exchange users? Check out the full discussion thread here.
If a program uses their own (un)installer systems, then there is nothing stopping you from running another uninstaller at the same time.
The Windows Installer limits the number of instances to avoid conflicts being made by multiple programs while they are changing system-wide (often shared) settings and files.
Most uninstallers track what they are changing so they can roll back successfully if there is a failure. If one is not aware of all the changes being made (by other uninstallers), then it may actually make things WORSE if it tries to roll back a failed install.
The Windows Installer system was created with the intention of being a unified system for all application developers to use (on Windows) in order to help avoid problems like these.