mt_amh_server.cpp
来自「这是广泛使用的通信开源项目,对于大容量,高并发的通讯要求完全能够胜任,他广泛可用」· C++ 代码 · 共 96 行
CPP
96 行
//
// MT_AMH_Server.cpp,v 1.3 2003/05/08 15:51:17 parsons Exp
//
#include "MT_AMH_Server.h"
#include "tao/Strategies/advanced_resource.h"
#include "ace/Task.h"
#include "ace/Get_Opt.h"
MT_AMH_Server::MT_AMH_Server (int& argc, char **argv)
: Base_Server (argc, argv)
{
}
MT_AMH_Server::~MT_AMH_Server (void)
{
}
void
MT_AMH_Server::usage (const char *message)
{
static const char * usage =
"invoke as: mt_server -o <ior_output_file> \n"
" -n <num_threads> \n"
"-s <sleep_time (in microseconds)> \n";
// @@ Mayur, why don't you just place the usage message directly in
// the below ACE_ERROR macro? It's not a big deal. It's just
// something we normally do.
//
// Mayur: Seems cleaner to me this way.
ACE_ERROR ((LM_ERROR, "%s : %s", message, usage));
}
int
MT_AMH_Server::parse_args (void)
{
// Let the base server parse it's argumrents first
if (Base_Server::parse_args () != 1)
{
this->usage ("");
ACE_OS::exit (1);
}
ACE_Get_Opt get_opts (this->argc_, this->argv_, "n:");
int c;
int count_argv = 0;
while ((c = get_opts ()) != -1)
{
++count_argv;
switch (c)
{
case 'n':
{
this->nthreads_ = ACE_OS::atoi (get_opts.opt_arg ());
{
// Added unneeded '{ & }' just to satisfy Win32
for (int i = count_argv; i <= this->argc_; ++i)
this->argv_ [i] = this->argv_ [i+2];
}
// Decrement the value of this->argc_ to reflect the removal
// of '-n' option.
this->argc_ = this->argc_ - 2;
return 1;
}
case '?':
default:
// Don't do anything.
break;
}
}
return 0;
}
void
MT_AMH_Server::start_threads (void)
{
// Each of this thread runs the event loop
this->activate (THR_NEW_LWP | THR_JOINABLE, this->nthreads_, 1);
this->thr_mgr ()->wait ();
}
int
MT_AMH_Server::svc (void)
{
run_event_loop ();
return 1;
}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?