如何关闭这样的线程?

wmjhl 2010-06-26 02:35:20
多个线程使用同一个线程函数,如何关闭单个线程?
我是把多个参数放在数据库里,根据数据库里有多少记录来开多少线程,线程函数是同一个
以下是开始线程代码

void FileSyncDlg::StartTask()
{
// TODO: 在此添加控件通知处理程序代码
HRESULT hr;
long count;
try
{
hr=m_pConn.CreateInstance("ADODB.Connection");
if(SUCCEEDED(hr))
{
hr=m_pConn->Open(_T("driver={SQL Server};Server=wmj;Database=test;UID=sa;PWD=wmjfllhl"),"","",adModeUnknown);
m_pRecordset.CreateInstance("ADODB.Recordset");
m_pRecordset->Open("select * from SyncFile",_variant_t((IDispatch*)m_pConn,TRUE),adOpenStatic,adLockOptimistic,adCmdText);
while(!m_pRecordset->adoEOF)
{
m_pRecordset->MoveNext();

}
count=m_pRecordset->GetRecordCount();
}
}
catch(_com_error e)
{
// 捕捉异常
CString errormessage;
errormessage.Format(_T("连接数据库失败!\r\n错误信息:%s"),e.ErrorMessage());
AfxMessageBox(errormessage);///显示错误信息
}
m_pConn->Close();
long j;
for(j=1;j<=count;j++)
{
CWinThread * p=AfxBeginThread(&FileSyncDlg::SyncThread,&count,THREAD_PRIORITY_NORMAL,0,CREATE_SUSPENDED);
p->ResumeThread();
}



以下是线程函数:
UINT FileSyncDlg::SyncThread(LPVOID param)
{
long * i=(long*) param;
HRESULT hr;
_ConnectionPtr conn;
_RecordsetPtr recordset;
try
{
hr=conn.CreateInstance("ADODB.Connection");
if(SUCCEEDED(hr))
{
hr=conn->Open(_T("driver={SQL Server};Server=wmj;Database=test;UID=sa;PWD=wmjfllhl"),"","",adModeUnknown);
recordset.CreateInstance("ADODB.Recordset");
recordset->Open("select * from SyncFile",_variant_t((IDispatch*)conn,TRUE),adOpenStatic,adLockOptimistic,adCmdText);
while(recordset->adoEOF)
{
recordset->MoveNext();
}

recordset->MoveFirst();
for(long j=1;j<*i;j++)
{
recordset->MoveNext();
}

}
}
catch(_com_error e)
{
// 捕捉异常
CString errormessage;
errormessage.Format(_T("连接数据库失败!\r\n错误信息:%s"),e.ErrorMessage());
AfxMessageBox(errormessage);///显示错误信息
}
_variant_t resource,method,path,day,hour,min,account,password;
resource=recordset->GetCollect("Resource");
method=recordset->GetCollect("Method");
path=recordset->GetCollect("BackupPath");
day=recordset->GetCollect("Day");
hour=recordset->GetCollect("Hour");
min=recordset->GetCollect("Min");
account=recordset->GetCollect("Account");
password=recordset->GetCollect("Password");
DWORD sleeptime=(day.intVal*24*3600000)+(hour.intVal*3600000)+(min.intVal*60000);
while(1)
{
SyncFiles(resource,path);

if(method.intVal==0)
Sleep(1000);
else
Sleep(sleeptime);
}
conn->Close();


return 0;
}

水平有限,还请多多指教!
...全文
76 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
jadyzdr 2010-06-26
  • 打赏
  • 举报
回复
过来学习的,帮你顶
m_nAdrs 2010-06-26
  • 打赏
  • 举报
回复
获取可用分+10
jwybobo2007 2010-06-26
  • 打赏
  • 举报
回复
最好的方式可以通过设置一些标量来控制线程自己退出,不然只能调用相应的杀线程函数来处理
lanneret1234 2010-06-26
  • 打赏
  • 举报
回复
想办法让线程函数能够返回!!而不是强制干掉
DontKissBossAss 2010-06-26
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 mszjk 的回复:]

每个线程都有一个线程id,CreateThread的时候会返回这个id,关闭的时候根据这个id关闭即可.
[/Quote]

这种做法是一个反面教材
mszjk 2010-06-26
  • 打赏
  • 举报
回复
每个线程都有一个线程id,CreateThread的时候会返回这个id,关闭的时候根据这个id关闭即可.
DontKissBossAss 2010-06-26
  • 打赏
  • 举报
回复
不明白你怎么设计的。如果说要他们退出的话,还是可以的,
因为你线程函数运行代码,托的比较长,所以,在关闭线程之前,你要保证数据库连接是没问题的,这点还行(你在本地连接的)

你可以,找到那个线程运行时间长的循环,添加&&判断条件,这个条件可能靠全局变量来传递了

如果运行时间都很短,就退出,感觉不用关闭线程,只等他们退出就好了

本课程采用了漫画+动手实操+练习讲授Python编程技能。课程简介:第11章 常用内置模块11.1 数学计算模块 —— math模块11.2 日期时间模块 —— datetime模块11.2.1 datetime类11.2.2 date类11.2.3 time类11.2.4 计算时间跨度类——timedelta11.2.5 将日期时间对象与字符串相互转换11.3 正则表达式模块 —— re模块11.3.1 字符串匹配11.3.2 字符串查找11.3.3 字符串替换11.3.4 字符串分割11.5 练一练第12章 文件读写12.1 打开文件12.2 关闭文件12.2.1 在finally代码块中关闭文件12.2.2 在with as代码块中关闭文件12.3 读写文本文件12.4 动动手 —— 复制文本文件12.5 读写二进制文件12.6 动动手 —— 复制二进制文件12.1 练一练第13章 图形用户界面13.1 Python中的图形用户界面开发库13.2 安装wxPython17813.3 第一个wxPython程序18013.4 自定义窗口类18213.5 在窗口中添加控件18213.6 事件处理18413.7 布局管理18513.7.1 盒子布局管理器18613.7.2 动动手——重构事件处理示例13.7.3 动动手——盒子布局管理器嵌套示例13.8 控件13.8.1 文本输入控件13.8.2 复选框和单选按钮13.8.3 列表13.8.4 静态图片控件13.9 点拨点拨 —— 如何使用wxPython官方文档13.10 练一练第14章 网络通信14.1 基本的网络知识14.1.1 TCP/IP14.1.2 IP地址14.1.3 端口14.1.4 HTTP/HTTPS14.2 搭建自己的Web服务器14.3 urllib.request模块14.3.1 发送GET请求14.3.2 发送POST请求14.4 JSON数据14.4.1 JSON文档的结构14.4.2 对JSON数据的解码14.5 动动手 —— 下载图片示例14.6 动动手 —— 返回所有备忘录信息14.7 练一练第15章 访问数据库15.1 SQLite15.1.1 SQLite的数据类型15.1.2 Python的数据类型与SQLite的数据类型的映射15.1.3 使用GUI管理工具管理SQLite15.2 数据库编程的基本操作过程15.3.1 数据库连接对象Connection15.3.2 游标对象Cursor15.4 动动手 —— 数据库的CRUD操作示例15.4.1 示例中的数据表15.4.2 无条件查询15.4.3 有条件查询15.4.4 插入数据15.4.5 更新数据15.4.6 删除数据15.5 点拨点拨 —— 防止SQL注入攻击15.6 练一练第16章 多线程16.1 线程相关的知识16.1.1 进程16.1.2 线程16.1.3 主线程16.2 线程模块 —— threading模块16.3 创建子线程16.3.1 自定义函数实现线程体16.3.2 自定义线程类实现线程体16.4 线程管理16.4.1 等待线程结束16.4.2 线程停止16.5 动动手 —— 下载图片示例16.6 练一练

15,471

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC 进程/线程/DLL
社区管理员
  • 进程/线程/DLL社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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