ServicedComponent Clase

Definición

Representa la clase base de todas las clases que utilizan servicios de COM+.Represents the base class of all classes using COM+ services.

public ref class ServicedComponent abstract : ContextBoundObject, IDisposable, System::EnterpriseServices::IRemoteDispatch, System::EnterpriseServices::IServicedComponentInfo
[System.Serializable]
public abstract class ServicedComponent : ContextBoundObject, IDisposable, System.EnterpriseServices.IRemoteDispatch, System.EnterpriseServices.IServicedComponentInfo
type ServicedComponent = class
    inherit ContextBoundObject
    interface IRemoteDispatch
    interface IDisposable
    interface IServicedComponentInfo
Public MustInherit Class ServicedComponent
Inherits ContextBoundObject
Implements IDisposable, IRemoteDispatch, IServicedComponentInfo
Herencia
Derivado
Atributos
Implementaciones

Ejemplos

En el ejemplo de código siguiente se muestra cómo exponer una clase como un componente COM configurado.The following code example demonstrates how to expose a class as a configured COM component.


[assembly:ApplicationName("Calculator")];
[assembly:ApplicationActivation(ActivationOption::Library)];
[assembly:System::Reflection::AssemblyKeyFile("Calculator.snk")];
public ref class Calculator: public ServicedComponent
{
public:
   int Add( int x, int y )
   {
      return (x + y);
   }

};

using System;
using System.EnterpriseServices;

[assembly: ApplicationName("Calculator")]
[assembly: ApplicationActivation(ActivationOption.Library)]
[assembly: System.Reflection.AssemblyKeyFile("Calculator.snk")]
public class Calculator : ServicedComponent
{
    public int Add (int x, int y)
    {
        return(x+y);
    }
}

Para implementar esta clase como un componente COM configurado, debe generar una clave segura, compilar la clase como una biblioteca y registrar la biblioteca.To deploy this class as a configured COM component, you must generate a strong key, compile the class as a library, and register the library. Estos tres pasos se realizan mediante los tres comandos siguientes.These three steps are accomplished by the following three commands.

sn -k Calculator.snk  
csc /t:library Calculator.cs  
regsvcs Calculator.dll  

Comentarios

En determinadas condiciones, una clase que se deriva de ServicedComponent que se ejecuta en una aplicación COM+ puede dejar de responder.Under certain conditions, a class that is derived from ServicedComponent that runs in a COM+ application may stop responding. Este problema se debe a un interbloqueo de actividad.This problem is caused by an Activity deadlock. Las actividades pueden interbloquearse en aplicaciones multiproceso debido a una limpieza asincrónica de las referencias de componentes.Activities can deadlock on multithreaded applications because of an asynchronous cleanup of component references. Para solucionar este problema, llame al método Dispose cuando termine de trabajar con objetos derivados de ServicedComponent.To work around this problem, call the Dispose method when you complete work with objects derived from ServicedComponent.

Nota

El código de cliente debe llamar a Dispose en los componentes con servicio para garantizar el funcionamiento correcto.Client code must call Dispose on serviced components to ensure proper operation.

Constructores

ServicedComponent()

Inicializa una nueva instancia de la clase ServicedComponent.Initializes a new instance of the ServicedComponent class.

Métodos

Activate()

La infraestructura se encarga de llamar a este método cuando el objeto se crea o se asigna desde una agrupación.Called by the infrastructure when the object is created or allocated from a pool. Reemplace este método para agregar código de inicialización personalizado a los objetos.Override this method to add custom initialization code to objects.

CanBePooled()

La infraestructura se encarga de llamar a este método cuando el objeto se crea o se asigna desde una agrupación de objetos.This method is called by the infrastructure before the object is put back into the pool. Reemplace este método para decidir si el objeto se devuelve a la agrupación.Override this method to vote on whether the object is put back into the pool.

Construct(String)

La infraestructura llama a este método justo después de que se llame al constructor, pasando la cadena de constructor.Called by the infrastructure just after the constructor is called, passing in the constructor string. Reemplace este método para poder utilizar el valor de la cadena de construcción.Override this method to make use of the construction string value.

CreateObjRef(Type)

Crea un objeto que contiene toda la información relevante necesaria para generar un proxy utilizado para comunicarse con un objeto remoto.Creates an object that contains all the relevant information required to generate a proxy used to communicate with a remote object.

(Heredado de MarshalByRefObject)
Deactivate()

La infraestructura llama a este método cuando el objeto está a punto de ser desactivado.Called by the infrastructure when the object is about to be deactivated. Reemplace este método para agregar código de finalización personalizado a los objetos cuando se utiliza código compilado just-in-time (JIT) o agrupamiento de objetos.Override this method to add custom finalization code to objects when just-in-time (JIT) compiled code or object pooling is used.

Dispose()

Libera todos los recursos que utiliza ServicedComponent.Releases all resources used by the ServicedComponent.

Dispose(Boolean)

Libera los recursos no administrados utilizados por ServicedComponent y, opcionalmente, libera también los recursos administrados.Releases the unmanaged resources used by the ServicedComponent and optionally releases the managed resources.

DisposeObject(ServicedComponent)

Finaliza el objeto y elimina la referencia de COM+ asociada.Finalizes the object and removes the associated COM+ reference.

Equals(Object)

Determina si el objeto especificado es igual que el objeto actual.Determines whether the specified object is equal to the current object.

(Heredado de Object)
GetHashCode()

Sirve como función hash predeterminada.Serves as the default hash function.

(Heredado de Object)
GetLifetimeService()

Recupera el objeto de servicio de duración actual que controla la directiva de duración de esta instancia.Retrieves the current lifetime service object that controls the lifetime policy for this instance.

(Heredado de MarshalByRefObject)
GetType()

Obtiene el Type de la instancia actual.Gets the Type of the current instance.

(Heredado de Object)
InitializeLifetimeService()

Obtiene un objeto de servicio de duración para controlar la directiva de duración de esta instancia.Obtains a lifetime service object to control the lifetime policy for this instance.

(Heredado de MarshalByRefObject)
MemberwiseClone()

Crea una copia superficial del Object actual.Creates a shallow copy of the current Object.

(Heredado de Object)
MemberwiseClone(Boolean)

Crea una copia superficial del objeto MarshalByRefObject actual.Creates a shallow copy of the current MarshalByRefObject object.

(Heredado de MarshalByRefObject)
ToString()

Devuelve una cadena que representa el objeto actual.Returns a string that represents the current object.

(Heredado de Object)

Implementaciones de interfaz explícitas

IRemoteDispatch.RemoteDispatchAutoDone(String)

Garantiza que, en el contexto de COM+, el valor del bit ServicedComponent del objeto de la clase done se establece en true después de invocarse un método remoto.Ensures that, in the COM+ context, the ServicedComponent class object's done bit is set to true after a remote method invocation.

IRemoteDispatch.RemoteDispatchNotAutoDone(String)

No garantiza que, en el contexto de COM+, el valor del bit ServicedComponent del objeto de la clase done se establezca en true después de invocarse un método remoto.Does not ensure that, in the COM+ context, the ServicedComponent class object's done bit is set to true after a remote method invocation.

IServicedComponentInfo.GetComponentInfo(Int32, String[])

Obtiene cierta información sobre la instancia de la clase ServicedComponent.Obtains certain information about the ServicedComponent class instance.

Se aplica a