client_task.cpp
来自「这是广泛使用的通信开源项目,对于大容量,高并发的通讯要求完全能够胜任,他广泛可用」· C++ 代码 · 共 202 行
CPP
202 行
//
// Client_Task.cpp,v 1.3 2003/05/08 15:51:17 parsons Exp
//
#include "Client_Task.h"
#include "tao/Strategies/advanced_resource.h"
#include "ace/Get_Opt.h"
#include "ace/High_Res_Timer.h"
#include "ace/Sched_Params.h"
#include "ace/Stats.h"
Client_Task::Client_Task (int &argc, char **argv)
: argc_ (argc)
, argv_ (argv)
, ior_ ("file://test.ior")
, iterations_ (1000)
{
}
int
Client_Task::parse_args (void)
{
ACE_Get_Opt get_opts (this->argc_, this->argv_, "k:n:");
int c;
while ((c = get_opts ()) != -1)
{
switch (c)
{
case 'k':
{
this->ior_ = get_opts.opt_arg ();
break;
}
case 'n':
{
int iterations = ACE_OS::atoi (get_opts.opt_arg ());
if (iterations >= 0 )
this->iterations_ = iterations;
break;
}
case '?':
default:
ACE_ERROR_RETURN ((LM_ERROR,
"usage: %s "
"-k <file that contains IOR> "
"-n <iterations> "
"\n",
this->argv_ [0]),
-1);
}
}
// Indicates sucessful parsing of the command line
return 1;
}
void
Client_Task::try_RT_scheduling (void)
{
int priority =
(ACE_Sched_Params::priority_min (ACE_SCHED_FIFO)
+ ACE_Sched_Params::priority_max (ACE_SCHED_FIFO)) / 2;
priority = ACE_Sched_Params::next_priority (ACE_SCHED_FIFO,
priority);
// Enable FIFO scheduling, e.g., RT scheduling class on Solaris.
if (ACE_OS::sched_params (ACE_Sched_Params (ACE_SCHED_FIFO,
priority,
ACE_SCOPE_PROCESS)) != 0)
{
if (errno == EPERM)
{
ACE_DEBUG ((LM_DEBUG,
"client (%P|%t): user is not superuser, "
"test runs in time-shared class\n"));
}
else
ACE_ERROR ((LM_ERROR,
"client (%P|%t): sched_params failed\n"));
}
}
int
Client_Task::narrow_servant (void)
{
ACE_TRY_NEW_ENV
{
CORBA::ORB_var orb =
CORBA::ORB_init (this->argc_, this->argv_, "" ACE_ENV_ARG_PARAMETER);
ACE_TRY_CHECK;
CORBA::Object_var object =
orb->string_to_object (this->ior_ ACE_ENV_ARG_PARAMETER);
ACE_TRY_CHECK;
this->roundtrip_ =
Test::Roundtrip::_narrow (object.in () ACE_ENV_ARG_PARAMETER);
ACE_TRY_CHECK;
if (CORBA::is_nil (this->roundtrip_.in ()))
{
ACE_ERROR_RETURN ((LM_ERROR,
"Nil Test::Roundtrip reference <%s>\n",
this->ior_),
0);
}
}
ACE_CATCHANY
{
// @@ Mayur, what use is there in placing a space before a
// newline character?
//
// Mayur: I feel the newline is easier to spot that way.
ACE_PRINT_EXCEPTION (ACE_ANY_EXCEPTION,
"Exception caught trying to narrow servant \n");
return 0;
}
ACE_ENDTRY;
return 1;
}
int
Client_Task::run_test (void)
{
ACE_hrtime_t test_start = 0;
ACE_hrtime_t test_end = 0;
ACE_DECLARE_NEW_CORBA_ENV;
ACE_TRY
{
test_start = ACE_OS::gethrtime ();
this->roundtrip_->start_test (ACE_ENV_SINGLE_ARG_PARAMETER);
ACE_TRY_CHECK;
this->svc ();
this->roundtrip_->end_test (ACE_ENV_SINGLE_ARG_PARAMETER);
ACE_TRY_CHECK;
test_end = ACE_OS::gethrtime ();
}
ACE_CATCHANY
{
return 0;
}
ACE_ENDTRY;
// High resolution timer calibration
ACE_UINT32 gsf = ACE_High_Res_Timer::global_scale_factor ();
ACE_Basic_Stats totals;
this->accumulate_and_dump (totals, "Task", gsf);
totals.dump_results ("Total", gsf);
ACE_Throughput_Stats::dump_throughput ("Total", gsf,
test_end - test_start,
totals.samples_count ());
return 1;
}
int
Client_Task::svc (void)
{
ACE_DECLARE_NEW_CORBA_ENV;
ACE_TRY
{
for (int i = 0; i != this->iterations_; ++i)
{
CORBA::ULongLong start = ACE_OS::gethrtime ();
(void) this->roundtrip_->test_method (start ACE_ENV_ARG_PARAMETER);
ACE_TRY_CHECK;
ACE_hrtime_t now = ACE_OS::gethrtime ();
this->latency_.sample (now - start);
}
}
ACE_CATCHANY
{
return 0;
}
ACE_ENDTRY;
return 1;
}
void
Client_Task::accumulate_and_dump (ACE_Basic_Stats &totals,
const char *msg,
ACE_UINT32 gsf)
{
totals.accumulate (this->latency_);
this->latency_.dump_results (msg, gsf);
}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?