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

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);
}
}
...全文
31 点赞 收藏 7
写回复
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。要如何写才是高效的。请大家帮帮忙?


回复
发动态
发帖子
Windows SDK/API
创建于2007-08-02

1202

社区成员

C++ Builder Windows SDK/API
申请成为版主
社区公告
暂无公告