TDispatcherThread derives from TThread. You instantiate this class by passing it the incoming stream (from the caller) and the dispatcher that you want to run. The incoming stream must be an instance of TReceiverStream.
TDispatcherThread::Main processes requests by:
- Calling the Receive function of the receiver stream.
- Running the dispatcher's DispatchRequest function, passing the argument stream.
- Sending the result stream (the reply) back to the caller, via the Reply function of the stream.
One way to create a dispatcher and start it processing (using TDispatcherThread) is to:
- Create a service definition.
The Service Access framework provides service definition classes for several types of services. Read Chapter 4, "Communications access," in OS Services.
- Create a pointer to the dispatcher implementation object.
- Instantiate a TRequestReceiverStream using the service definition object.
- Create a dispatcher object, passing in a dispatcher implementation object.
- Instantiate TDispatcherThread, passing the pointer to the receiver stream and a new dispatcher.
The TDispatcherThread object adopts the receiver stream and the dispatcher.
- Call the Start function to start the thread.
- Call WaitForDeath.
This example shows the main() for the calculator dispatcher:
void
main()
{
TQualityOfService serviceQuality(TQualityOfService::kSameHost);
TStandardServiceDefinition* serviceDefinition =
new TStandardServiceDefinition(
TLocalObjectName("RPCAdditionDispatcher"), serviceQuality);
TAdditionImplementation* dispatcherImp = new TAdditionImplementation;
TRequestReceiverStream* receiverStream
= new TRequestReceiverStream(serviceDefinition);
TAdditionDispatcher* dispatcher = new TAdditionDispatcher(dispatcherImp);
TDispatcherThread thread(receiverStream, dispatcher);
thread.Start();
thread.WaitForDeath();
}
[Contents]
[Previous]
[Next]
Click the icon to mail questions or corrections about this material to Taligent personnel.
Copyright©1995 Taligent,Inc. All rights reserved.
Generated with WebMaker