NET Interoperability
How can we use COM Components in .NET? |
.NET components communicate with COM using RCW (Runtime Callable Wrapper). Following are the ways with which you can generate RCW :
|
Once I have developed the COM wrapper do I have to still register the COM in registry? |
Yes |
How can we use .NET components in COM? |
.NET components can not be used in straight forward way with COM. You will need to create CCW (COM Callable Wrapper) in order that COM components communicate with .NET assemblies. Following are the different approaches to implement it: Explicitly declare interfaces. Public Interface ICustomer The above customer class is going to be used by COM components so all the properties and methods are declared in interface and implemented in the customer class. Customer Name.Customer Code and AddCustomer are first declared in ICustomer and then implemented in Customer Class. Also note that the class must have a default constructor. To create CCW is by using InteropServices attributes. Here interfaces are created automatically Following are different type of class attributes : AutoDispatch:Interface that supports IDispatch is created for the class. However, no type information is produced. AutoDual :A dual interface is created for the class. Type information is produced and made available in the type library. Below is an example of code that uses third attribute: Imports System.Runtime.InteropServices _
<ClassInterfaceAttribute(ClassInterfaceType.AutoDual)> _ Public Class ClsCompliant End Class Other than class attributes defined up there are other attributes with which you can govern other part of assembly. Example "GuidAttribute" allows you to specify the GUID, "ComVisibleAttribute" can be used to hide .NET types from COM etc. Once .NET assembly is created using either interface or using interopservices method we need to create a COM type library using Type library export tool. Tlbexp (AssemblyName) The final thing is registering the CCW in registry using regasm tool. regasm AssemblyName [Options] Finally refer the TLB in your COM IDE. DLL and TLB should be in same directory where the application is executed.
|
How can we make Windows API calls in .NET? |
Windows API call are not COM based and they are invoked through Platform Invoke Services. Declare StringConversionType (Function | Sub) MethodName Lib "DllName" ([Args]) As Type where Below is a sample code for VB.NET which uses Sleep windows API for delaying. Public Class Form1
Declare Auto Sub Sleep Lib "kernel32.dll" (ByVal dwMilliseconds As Long) Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load MessageBox.Show(" start sleeping for 5000 Milliseconds.....") Sleep(5000) MessageBox.Show(" end of sleeping.....") End Sub End Class And also example in C#: #region Using directives ;using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Windows.Forms; using System.Runtime.InteropServices; #endregion namespace CSharpCode { partial class Form1 : Form { [DllImport("Kernel32.dll")] static extern int Sleep(long dwMilliseconds); public Form1() { InitializeComponent(); } private void Form1_Load(object sender, EventArgs e) { MessageBox.Show("Starting of 5000 ms..."); Sleep(5000); MessageBox.Show("End of 5000 ms..."); } } } |
When we use Windows API in .NET is it managed or unmanaged code? |
Windows API in .NET is unmanaged code. |
What is COM? |
Microsoft’s COM is a technology for component software development. It is a binary standard which is language independent. DCOM is a distributed extension of COM. |
What is Reference counting in COM? |
Reference counting is a memory management technique used to count how many times an object has a pointer referring to it. The first time it is created, the reference count is set to one. When the last reference to the object is nulled, the reference count is set to zero and the object is deleted. Care must be exercised to prevent a context switch from changing the reference count at the time of deletion. |
Can you describe IUnknown interface in short? |
Every COM object supports at least one interface, the IUnknown interface. All interfaces are classes derived from the base class IUnknown. Each interface supports methods access data and perform operations transparently to the programmer. For example, IUnknown supports three methods, AddRef, Release(), and QueryInterface(). Suppose that pinterf is a pointer to an IUnknown.pinterf->AddRef() increments the reference count.pinterf->Release() decrements the reference count, deleting the object when the reference count reaches zero. pinterf->QueryInterface( IDesired, pDesired) checks to see if the current interface (IUnknown) supports another interface, IDesired, creates an instance (via a call to CoCreateInstance()) of the object if the reference count is zero (the object does not yet exist), and then calls pDesired->AddRef() to increment the reference count (where pDesired is a pointer to IDesired) and returns the pointer to the caller. |
DCOM differs from COM in that it allows for creating objects distributed across a network, a protocol for invoking that object’s methods, and secures access to the object. DCOM provides a wrapper around COM, hence it is a backwards compatible extension. DCOM uses Remote Procedural Calls (RPC) using Open Software Foundation’s Distributed Computing Environment. These RPC are implemented over TCP/IP and named pipes. The protocol which is actually being used is registered just prior to use, as opposed to being registered at initialization time. The reason for this is that if a protocol is not being used, it will not be loaded. In order to inform an object that the client is still alive, periodic pinging is used. Hence, when the client has died and no ping has been received (to refresh it) before the expiration time, the server object will perform some clean up tasks (including decrementing its reference count). Since RPC across a network are typically slow (compared to processes residing on the same machine), DCOM sends multiple requests in the same call. For example, in COM, the program performs a QueryInterface, one interface at a time. In DCOM, multiple QueryInterfaces are all clustered into one call. This clustering optimization trick is also used when creating an instance of the object and serializing it with data. Since these two operations usually occur together, DCOM allows one method which will perform both operations in one call without waiting for an acknowledgment from the first task before performing the second one. Similarly, when a client pings its server object, he can do it in one call. Moreover, if there are multiple clients sending pings to multiple servers, an optimization is made where the multiple pings going to the same object are consolidated into just one ping. This is to cut down on the use of precious bandwidth used only for pinging. The client has the control to set the computer which will be responsible for the lifetime of the object. That is to say, these objects are not created just somewhere where the system resources and access privileges allow for it. Call security is implemented in all four ways: authentication (to prevent false clients from impersonating the true client), authorization (to insure that a client only does what it is authorized to do), data integrity (to insure that data was not tampered with during transit) and data privacy (to insure that only designated sources can read it). The security issues are handled as they are on operating systems. The client gives the server various access privileges to access memory or disk space. |
How do we create DCOM object in VB6? |
Using the CreateObject method you can create a DCOM object. You have to put the server name in the registry. |
How to implement DTC (Distributed Transactions Coordinator) in .NET ? |
DTC is implemented using COM+. Following are the steps to implement COM + in .NET :
public void SampleFunction()
|
How many types of Transactions are there in COM + .NET? |
There are 5 transactions types that can be used with COM+. Whenever an object is registered with COM+ it has to abide either to these 5 transaction types. Disabled: There is no transaction. COM+ does not provide transaction support for this component. Not Supported: Component does not support transactions. Hence even if the calling component Supported: Components with transaction type support will be a part of the transaction. This will be only if the calling component has an active transaction. If the calling component is not transaction enabled this component will not start a new transaction. Required: Components with this attribute require a transaction i.e. either the calling should have a transaction in place else this component will start a new transaction. Required New: Components enabled with this transaction type always require a new transaction. Components with required new transaction type instantiate a new transaction for themselves every time. |
How do you do object pooling in .NET? |
COM+ reduces overhead by creating object from scratch. So in COM+ when object is activated its activated from pool and when its deactivated it’s pushed back to the pool. Object pooling is configures by using the "ObjectPoolingAttribute" to the class. When a class is marked with objectpooling attribute it can not be inherited. Public Class TestingClass Inherits ServicedComponent
Public Sub DoWork() ' Method contents go here. End Sub End Class Below is a sample code which uses the class. Public Class App
Overloads Public Shared Sub Main(args() As String) Dim xyz As New TestObjectPooling() xyz.doWork() ServicedComponent.DisposeObject (xyz) End Sub End Class Note the DisposeObject() This ensures its safe return to the object pool. |
What are types of compatibility in VB6? |
|
What is equivalent for regsvr32 exe in .NET ? |
Regasm.exe - The Assembly Registration tool reads the metadata within an assembly and adds the necessary entries to the registry, which allows COM clients to create .NET Framework classes transparently. |
Comments
Post a Comment