为何我的这个服务一启动就说已经停止了??

gyj_china 2003-12-24 10:55:00
刚学写服务,不足之处请大家多帮忙。
代码就下面一点点。
void __fastcall TService1::ServiceExecute(TService *Sender)
{
while(!Terminated)
{
ADOQuery1->SQL->Clear();
ADOQuery1->SQL->Add("select top 1 flag from test where flag = 0");
ADOQuery1->Open();
ADOQuery1->Edit();
while (!ADOQuery1->Eof)
{
ADOQuery1->FieldValues["flag"] = 1;
ADOQuery1->Next();
}
ADOQuery1->Post();
ServiceThread->ProcessRequests(false);
}
}
...全文
116 7 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
gyj_china 2003-12-24
  • 打赏
  • 举报
回复
晕,原来是这样?我试试。
netsys2 2003-12-24
  • 打赏
  • 举报
回复
while(!Terminated)
{
ADOQuery1->SQL->Clear();
ADOQuery1->SQL->Add("select top 1 flag from test where flag = 0");
//上面的SQL语句好奇怪啊,select top 1 flag?
ADOQuery1->Open();
ADOQuery1->Edit();
while (!ADOQuery1->Eof)
{
ADOQuery1->FieldValues["flag"] = 1;
ADOQuery1->Next();
ADOQuery1->Post();
}
this->Terminate();
// ServiceThread->ProcessRequests(false);
}
NowCan 2003-12-24
  • 打赏
  • 举报
回复
这个要具体情况具体分析了。你好像是要对test表不断的写1,所以写入频率和test表被别的程序修改的频率有关。
netsys2 2003-12-24
  • 打赏
  • 举报
回复
Sleep(500)会不会影响程序执行的效率?

有些影响,但你不让CPU太满,当然只要这样了。

你可以测试,看Sleep()多少合适。
gyj_china 2003-12-24
  • 打赏
  • 举报
回复
OK,通过,但是我有个疑问,Sleep(500)会不会影响程序执行的效率?
我不懂电脑 2003-12-24
  • 打赏
  • 举报
回复
void __fastcall TService1::ServiceExecute(TService *Sender)
{
while(!Terminated)
{
ADOQuery1->SQL->Clear();
ADOQuery1->SQL->Add("select * from test where flag = 0");
ADOQuery1->Open();
ADOQuery1->Edit();
while (!ADOQuery1->Eof)
{
ADOQuery1->FieldValues["flag"] = 1;
ADOQuery1->Post();
ADOQuery1->Next();
}
Sleep(100);
ServiceThread->ProcessRequests(false);
}
}
gyj_china 2003-12-24
  • 打赏
  • 举报
回复
void __fastcall TService1::ServiceExecute(TService *Sender)
{
while(!Terminated)
{
ADOQuery1->SQL->Clear();
ADOQuery1->SQL->Add("select * from test where flag = 0");
ADOQuery1->Open();
ADOQuery1->Edit();
while (!ADOQuery1->Eof)
{
ADOQuery1->FieldValues["flag"] = 1;
ADOQuery1->Post();
ADOQuery1->Next();
}
ServiceThread->ProcessRequests(false);
}
}
谢谢上面的提示,我这样做了以后,CPU的资源利用率被它用掉了90%,这个服务是到一个test表中找到字段flag值为0的记录,并将它更改为1。要如何写才是高效的。请大家帮帮忙?


1,222

社区成员

发帖
与我相关
我的任务
社区描述
C++ Builder Windows SDK/API
社区管理员
  • Windows SDK/API社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧