Tuesday, November 4, 2008

COM- Early binding and Late binding in Automation

Classic COM doesn't exist in a managed environment, because it executes as instructions native to Windows.COM objects can be brought into managed environment by using a wrapper (the runtime callable wrapper). Two methods can be used to access a COM object
-early bound access (types are known at compile time) -[tlbimp.exe or vs.net Add reference]
-late bound access (type discovery and method invocation are performed at runtime).
Which form of binding is best?
The answer to this question depends as much on the design of your project as anything else. Microsoft recommends early binding in almost all cases. However, there may be reasons for choosing late binding.
Early binding is the preferred method. It is the best performer because your application binds directly to the address of the function being called and there is no extra overhead in doing a run-time lookup. In terms of overall execution speed, it is at least twice as fast as late binding.
Early binding also provides type safety. When you have a reference set to the component's type library, Visual Basic provides IntelliSense support to help you code each function correctly. Visual Basic also warns you if the data type of a parameter or return value is incorrect, saving a lot of time when writing and debugging code.
Late binding is still useful in situations where the exact interface of an object is not known at design-time. If your application seeks to talk with multiple unknown servers or needs to invoke functions by name (using the Visual Basic 6.0 CallByName function for example) then you need to use late binding. Late binding is also useful to work around compatibility problems between multiple versions of a component that has improperly modified or adapted its interface between versions.
The advantages given to early binding make it the best choice whenever possible.
for more details visit here

No comments:

Post a Comment