VC下利用多线程实现文件的快速检索

本文介绍了如何在VC++环境下利用多线程技术提高文件搜索的效率。通过创建线程函数和使用FindFirstFile及FindNextFile函数,实现了同步搜索。文章详细讲解了线程参数结构、互斥体、事件通知以及线程的管理和终止方法。
摘要由CSDN通过智能技术生成

VC下利用多线程实现文件的快速检索
2004-07-30■作者:冯杰■出处:天极网


操作系统一般都提供了文件搜索的功能,但采用的是顺序搜索,搜索效率很低。而且按此法编程十分烦琐,在目录层次很多时,往往不好处理。本文采用多线程技术实现文件的快速搜索,代码量很少,执行效率极高。

本文提出的多线程文件搜索的基本思想很简单,就是找到一个目录就开辟一个线程,而找到一个文件当然在线程内就处理了,这样实现了同步搜索。

 

以下介绍其在vc平台下的具体实现:

1.搜索用到两个win32的两个函数

HANDLE FindFirstFile(LPCTSTR lpFileName,LPWIN32_FIND_DATA lpFindFileData );
BOOL FindNextFile( HANDLE hFindFile, LPWIN32_FIND_DATA lpFindFileData );

2. 建立线程函数
首先要定义线程的参数结构用于文件信息的传递:

typedef struct tagTHREADPARAM {
 CString strPath;
 CString strFileName;
}THREADPARAM m_param;

因为线程要操纵全局变量,所以定义互斥体:

CMutex m_mutexThreadCount,m_mutexThreadParam,m_mutexPath;

如果搜索完毕或搜索终止,要有事件通知,于是创建一个事件:

CEvent m_event(FALSE,FALSE,NULL,NULL);
UINT uThreadCount=0;//产生的线程数
CStringArray m_strPathArray;//存

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值