spipe-acceptor.h
来自「ACE自适配通信环境(ADAPTIVE Communication Enviro」· C头文件 代码 · 共 80 行
H
80 行
/* -*- C++ -*- */// SPIPE-acceptor.h,v 4.9 2005/01/29 16:21:03 mcorino Exp#ifndef SP_ACCEPTOR_H#define SP_ACCEPTOR_H#include "ace/Svc_Handler.h"#include "ace/Service_Config.h"#if !defined (ACE_LACKS_PRAGMA_ONCE)# pragma once#endif /* ACE_LACKS_PRAGMA_ONCE */#include "ace/Acceptor.h"#include "ace/SPIPE_Stream.h"#include "ace/SPIPE_Acceptor.h"#include "ace/Asynch_IO.h"// This only works on Win32 platforms and on Unix platforms// supporting POSIX aio calls.#if ((defined (ACE_WIN32) && !defined (ACE_HAS_WINCE)) || (defined (ACE_HAS_AIO_CALLS)))// This is the class that does the work once the ACE_Oneshot_Acceptor// has accepted a connection.class Svc_Handler : public ACE_Svc_Handler <ACE_SPIPE_STREAM, ACE_NULL_SYNCH>, public ACE_Handler{public: Svc_Handler (void); ~Svc_Handler (void); virtual int open (void *); virtual void handle_read_stream (const ACE_Asynch_Read_Stream::Result &result); // This is called when asynchronous read from the socket complete // Handle data from the client.private: ACE_Asynch_Read_Stream ar_; ACE_Message_Block mb_;};class IPC_Server : public ACE_Oneshot_Acceptor<Svc_Handler, ACE_SPIPE_ACCEPTOR>{public: IPC_Server (void); ~IPC_Server (void); // = Dynamic linking hooks. virtual int init (int argc, ACE_TCHAR *argv[]); // Initialize the network server. virtual int fini (void); // Close down the server. virtual int svc (void); // Run the interative service.private: int parse_args (int argc, ACE_TCHAR *argv[]); // Parse command-line arguments. int n_threads_; // Size of thread pool to use. ACE_TCHAR rendezvous_[MAXPATHLEN + 1]; // Meeting place for pipe. int shutdown_; // Keeps track of when we shut down due to receipt of the SIGINT // signal. int handle_signal (int signum, siginfo_t *, ucontext_t *); // Signal handler method.};#endif /* ACE_WIN32 || ACE_HAS_AIO_CALLS*/#endif /* SP_ACCEPTOR_H */
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?