From the Developers Guide

To successfully deploy your .NET Framework application, you must understand how the common language runtime locates and binds to the assemblies that make up your application. By default, the runtime attempts to bind with the exact version of an assembly that the application was built with. This default behavior can be overridden by configuration file settings.

The common language runtime performs a number of steps when attempting to locate an assembly and resolve an assembly reference. Each step is explained in the following sections. The term probing is often used when describing how the runtime locates assemblies; it refers to the set of heuristics used to locate the assembly based on its name and culture.

Here are some links that describe the steps in the resolution process.

http://msdn.microsoft.com/en-us/library/yx7xezcf(VS.71).aspx

http://msdn.microsoft.com/en-us/library/8f6988ab(VS.71).aspx

http://msdn.microsoft.com/en-us/library/aa98tba8(VS.71).aspx

http://msdn.microsoft.com/en-us/library/4a9t8a9a(VS.71).aspx

http://msdn.microsoft.com/en-us/library/15hyw9x3(VS.71).aspx