ServicedComponent ServicedComponent ServicedComponent ServicedComponent Class

Определение

Представляет базовый класс для всех классов, используя службы 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
Наследование
Производный
Атрибуты
Реализации

Примеры

В следующем примере кода показано, как предоставить класс как настроенный COM-компонент.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);
    }
}

Чтобы развернуть этот класс в качестве настроенного компонента COM, необходимо создать надежный ключ, скомпилировать класс в качестве библиотеки и зарегистрировать библиотеку.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. Эти три шага выполняются следующими тремя командами.These three steps are accomplished by the following three commands.

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

Комментарии

При определенных условиях класс, производный от ServicedComponent , который выполняется в приложении COM+, может перестать отвечать на запросы.Under certain conditions, a class that is derived from ServicedComponent that runs in a COM+ application may stop responding. Эта проблема вызвана взаимоблокировкой действия.This problem is caused by an Activity deadlock. Действия могут взаимоблокироваться в многопоточных приложениях из-за асинхронной очистки ссылок на компоненты.Activities can deadlock on multithreaded applications because of an asynchronous cleanup of component references. Чтобы обойти эту проблему, вызовите Dispose метод при завершении работы с объектами, производными от. ServicedComponentTo work around this problem, call the Dispose method when you complete work with objects derived from ServicedComponent.

Примечание

Клиентский код должен вызвать Dispose на обслуживаемом компоненте, чтобы гарантировать правильную работу.Client code must call Dispose on serviced components to ensure proper operation.

Конструкторы

ServicedComponent() ServicedComponent() ServicedComponent() ServicedComponent()

Инициализирует новый экземпляр класса ServicedComponent.Initializes a new instance of the ServicedComponent class.

Методы

Activate() Activate() Activate() Activate()

Вызывается инфраструктурой при создании объекта или его выделении из пула.Called by the infrastructure when the object is created or allocated from a pool. Чтобы добавить для объектов пользовательский код инициализации, следует переопределить этот метод.Override this method to add custom initialization code to objects.

CanBePooled() CanBePooled() CanBePooled() CanBePooled()

Этот метод вызывается инфраструктурой перед возвращением объекта в пул.This method is called by the infrastructure before the object is put back into the pool. Чтобы иметь возможность выбрать, возвращать объект в пул или нет, следует переопределить этот метод.Override this method to vote on whether the object is put back into the pool.

Construct(String) Construct(String) Construct(String) Construct(String)

Вызывается инфраструктурой сразу после вызова конструктора при передаче строки конструктора.Called by the infrastructure just after the constructor is called, passing in the constructor string. Чтобы сделать возможным использование значения строки конструирования, следует переопределить этот метод.Override this method to make use of the construction string value.

CreateObjRef(Type) CreateObjRef(Type) CreateObjRef(Type) CreateObjRef(Type)

Создает объект, который содержит всю необходимую информацию для создания прокси-сервера, используемого для взаимодействия с удаленным объектом.Creates an object that contains all the relevant information required to generate a proxy used to communicate with a remote object.

(Inherited from MarshalByRefObject)
Deactivate() Deactivate() Deactivate() Deactivate()

Вызывается инфраструктурой перед тем, как объект будет отключен.Called by the infrastructure when the object is about to be deactivated. Этот метод следует переопределить для добавления в объекты пользовательского кода завершения при использовании JIT-скомпилированного кода или пула объектов.Override this method to add custom finalization code to objects when just-in-time (JIT) compiled code or object pooling is used.

Dispose() Dispose() Dispose() Dispose()

Освобождает все ресурсы, занятые модулем ServicedComponent.Releases all resources used by the ServicedComponent.

Dispose(Boolean) Dispose(Boolean) Dispose(Boolean) Dispose(Boolean)

Освобождает неуправляемые ресурсы, используемые объектом ServicedComponent, а при необходимости освобождает также управляемые ресурсы.Releases the unmanaged resources used by the ServicedComponent and optionally releases the managed resources.

DisposeObject(ServicedComponent) DisposeObject(ServicedComponent) DisposeObject(ServicedComponent) DisposeObject(ServicedComponent)

Завершает объект и удаляет соответствующую ссылку COM+.Finalizes the object and removes the associated COM+ reference.

Equals(Object) Equals(Object) Equals(Object) Equals(Object)

Определяет, равен ли заданный объект текущему объекту.Determines whether the specified object is equal to the current object.

(Inherited from Object)
GetHashCode() GetHashCode() GetHashCode() GetHashCode()

Служит хэш-функцией по умолчанию.Serves as the default hash function.

(Inherited from Object)
GetLifetimeService() GetLifetimeService() GetLifetimeService() GetLifetimeService()

Извлекает объект обслуживания во время существования, который управляет политикой времени существования данного экземпляра.Retrieves the current lifetime service object that controls the lifetime policy for this instance.

(Inherited from MarshalByRefObject)
GetType() GetType() GetType() GetType()

Возвращает объект Type для текущего экземпляра.Gets the Type of the current instance.

(Inherited from Object)
InitializeLifetimeService() InitializeLifetimeService() InitializeLifetimeService() InitializeLifetimeService()

Получает объект службы времени существования для управления политикой времени существования для этого экземпляра.Obtains a lifetime service object to control the lifetime policy for this instance.

(Inherited from MarshalByRefObject)
MemberwiseClone() MemberwiseClone() MemberwiseClone() MemberwiseClone()

Создает неполную копию текущего объекта Object.Creates a shallow copy of the current Object.

(Inherited from Object)
MemberwiseClone(Boolean) MemberwiseClone(Boolean) MemberwiseClone(Boolean) MemberwiseClone(Boolean)

Создает неполную копию текущего объекта MarshalByRefObject.Creates a shallow copy of the current MarshalByRefObject object.

(Inherited from MarshalByRefObject)
ToString() ToString() ToString() ToString()

Возвращает строку, представляющую текущий объект.Returns a string that represents the current object.

(Inherited from Object)

Явные реализации интерфейса

IRemoteDispatch.RemoteDispatchAutoDone(String) IRemoteDispatch.RemoteDispatchAutoDone(String) IRemoteDispatch.RemoteDispatchAutoDone(String) IRemoteDispatch.RemoteDispatchAutoDone(String)

Гарантирует, что в контексте COM+ для объекта класса ServicedComponent бит done устанавливается в значение true после удаленного вызова метода.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) IRemoteDispatch.RemoteDispatchNotAutoDone(String) IRemoteDispatch.RemoteDispatchNotAutoDone(String) IRemoteDispatch.RemoteDispatchNotAutoDone(String)

Не гарантирует, что в контексте COM+ для объекта класса ServicedComponent для бита done устанавливается значение true после удаленного вызова метода.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[]) IServicedComponentInfo.GetComponentInfo(Int32, String[]) IServicedComponentInfo.GetComponentInfo(Int32, String[]) IServicedComponentInfo.GetComponentInfo(Int32, String[])

Получает определенную информацию об экземпляре класса ServicedComponent.Obtains certain information about the ServicedComponent class instance.

Применяется к