Why won't normal uninstalls remove values from the registry?

Solution 1:

Because it is impossible.

The registry has multiple root nodes, but only two interesting ones: LocalMachine and CurrentUser. Normally, the setup writes values into LocalMachine, and the running program ONLY writes into CurrentUser (actually, unless the setup messes with the permissions, the running program can't write into LocalMachine.)

While keeping leftovers in LocalMachine is laziness, as pointed out by the other answers, it is not possible to clean the User part.

If a program is installed per machine (which most are) and multiple users use it, what should the uninstaller do? It could safely remove the user settings of the current account, but the current account might not be your account. (This happens if you started the uninstaller from a non admin account and then entered the credentials of an admin account - the setup is now running under that account, not the first one).

What about the other users? It could try to enumerate all users, but their registry keys might not be loaded. (Windows is lazy and only loads the things it needs.)

But you shouldn't even try that one. If you use roaming profiles, for example for terminal services, and then delete all settings on uninstall, you could really mess up and delete stuff that is actually still in use.

A terminal server is basically one windows machine where multiple users log-in at the same time and use applications.

Say you have two terminal servers running one application. You uninstall the application on TS1, now all the settings for all users are gone on TS2 because you have roaming profiles. oops.

The same also applies to files in the per-user directories.

In the setup of my companies program, I delete the per-machine stuff but don't touch the per-user stuff, not even of the user currently running the setup.

Solution 2:

There are many reasons this is the case, however it is not the fault of Microsoft or the Windows operating systems.

The following is a list of some the cases and reasons behind leaving registry entries:

  • Bad programming - The developer did not write the application uninstaller properly and the registry entries are left behind. In addition to that, the uninstaller might not have/use the proper permissions to remove the registry entries. It could also be that there is more than one application that uses those keys. For instances, two applications from the same developer, that writes to the same keys.

  • Left on purpose - As one comment mentioned, these entries could have been left on purpose. Some applications have a trial period and after that period you might choose to remove the application. If you choose to reinstall the application later, those keys give the application information on when it was installed. In addition to that, some developers might choose to leave those keys in case you choose to reinstall the application. If the developer used registry keys to store your customizations, they might leave them there, so when you reinstall all of your customizations persist. In the grand scheme, registry keys just take up a few bytes.

Should you remove the keys? That depends. The Windows registry is a dangerous place to mess around in. You can inadvertently break your system. Leaving the extraneous keys will not hurt the system. Some people will say cleaning/defragging the registry will speed up your system, but that has been proven false repeatedly.

If you really want to get rid of those programs, there are some uninstaller tools that can remove every trace of a program. These programs will watch the installer of another program and record all the actions done to the file system and registry and then completely remove those actions. One issue with these tools is that it is possible that they can remove things you might want to keep.