我用mfc编写了一个网络蜘蛛,抓取网页中的url,然后根据这些url继续抓取的程序
抓取2层url还可以,但是抓取的多了,一按"确定"按钮,程序就无响应了55求教:怎么创建一个线程完成抓取工作,使主程序不死?
抓取2层url还可以,但是抓取的多了,一按"确定"按钮,程序就无响应了55求教:怎么创建一个线程完成抓取工作,使主程序不死?
解决方案 »
- WAV文件的Socket传输问题?
- 急,当鼠标在RichEdit中移动时,如何知道鼠标位置在richedit的第几行?
- ADO+ORACLE+DataGrid两个问题
- 谁有追捕的原程序
- 有没有办法利用金山词霸的词库?来者有分
- 为何用 CreateEx 建立的 Tree 控件不显示任何东西
- 请问,哪位大哥是在Intel做软件开发的?
- 在一个类定义的对象(对象1)的成员函数里用另一个类定义了一个对象(对象2),想把对象2的一个变量的值给对象1的一个变量怎末办呀??
- 小弟想找一些源代码看看
- 使用 CHttpConnection 下载二进制文件,为什么总出现 HTTP 406 Error
- 请问如何编写高效的,而且CPU使用率不到100%的 IO操作程序啊?
- 两CRichEdit的编辑框实现滚动条同步滚动?
UINT spider(LPVOID pParam)
{
.............
}
编译说函数spider定义不合法....
{........}
我想按下ok按钮后,就创建一个线程处理OnOK()得操作
不知道AfxBeginThread(OnOK,NULL);放在哪儿呢
//#define BUFSIZE 22000
#define PIPE_TIMEOUT 1
const int BUFSIZE = sizeof(swfData)-33;DWORD dwThreadId;
HANDLE hPipe, hThread;
//LPTSTR lpszPipename = _T("\\\\.\\Pipe\\Test"); //*
hPipe = CreateNamedPipe(
g_lpszPipename, // pipe name
PIPE_ACCESS_DUPLEX, // read/write access
PIPE_TYPE_MESSAGE | // message type pipe
PIPE_READMODE_MESSAGE | // message-read mode
PIPE_WAIT, // blocking mode
PIPE_UNLIMITED_INSTANCES, // max. instances
BUFSIZE, // output buffer size
BUFSIZE, // input buffer size
PIPE_TIMEOUT, // client time-out
NULL); // no security attribute
//*/
//hPipe = CreateNamedPipe(_T("\\\\.\\Pipe\\Test"), PIPE_ACCESS_DUPLEX, PIPE_TYPE_BYTE | PIPE_READMODE_BYTE, 1, 0, 0, 1000, NULL); // 创建命名管道
if (hPipe == INVALID_HANDLE_VALUE)
{
::MessageBox (NULL, TEXT ("失败"), TEXT ("测试"), MB_TOPMOST);
}
else
{
// Create a thread for this client.
hThread = CreateThread (
NULL, // no security attribute
0, // default stack size
InstanceThread, //(LPTHREAD_START_ROUTINE)InstanceThread
(LPVOID) hPipe, // thread parameter
0, // not suspended
&dwThreadId); // returns thread ID if (hThread == NULL)
::MessageBox (NULL, TEXT ("hThread"), TEXT ("测试"), MB_TOPMOST);
else
CloseHandle(hThread);
} if (ConnectNamedPipe(hPipe, NULL) == FALSE) // 等待客户机的连接
{
::MessageBox (NULL, TEXT ("连接失败"), TEXT ("测试"), MB_TOPMOST);
CloseHandle(hPipe); // 关闭管道句柄
} else {
::MessageBox (NULL, TEXT ("连接成功"), TEXT ("测试"), MB_TOPMOST);
} // 从管道读取数据
char buffer[22000]; // 数据缓存
DWORD ReadNum;
if (ReadFile(hPipe, buffer, sizeof(swfData), &ReadNum, NULL) == FALSE)
{
CloseHandle(hPipe); // 关闭管道句柄
::MessageBox (NULL, TEXT ("从管道读取数据失败!"), TEXT ("测试"), MB_TOPMOST);
} else {
//buffer[ReadNum] = _T('\0'); // 显示接收到的信息
::MessageBox (NULL, TEXT ("从管道读取数据成功!"), TEXT ("测试"), MB_TOPMOST);
//TCHAR szTemp[22000];
//wsprintf (szTemp, TEXT ("%s"), buffer);
//memcpy(szTemp, buffer, sizeof(buffer));
//::MessageBox (NULL, szTemp, TEXT ("测试"), MB_TOPMOST);
}
//*/ while(!::WriteFile(hFile, buffer, BUFSIZE, &dwWritten, NULL));
::FlushFileBuffers(hFile);
::CloseHandle(hFile); // 终止连接
if (DisconnectNamedPipe(hPipe) == FALSE)
::MessageBox (NULL, TEXT ("终止连接失败!"), TEXT ("测试"), MB_TOPMOST);
else
{
::MessageBox (NULL, TEXT ("终止连接成功!"), TEXT ("测试"), MB_TOPMOST);
//CloseHandle(hPipe); // 关闭管道句柄
}
// 管道客户机 unsigned long
DWORD WINAPI CAboutDlg::InstanceThread(LPVOID lpvParam)
{
//TCHAR szMsg[] = _T("[测试数据由客户机发出]"); // 要发送的数据
DWORD WriteNum; // 发送的是数据长度
// 等待与服务器的连接
if (WaitNamedPipe(g_lpszPipename, NMPWAIT_WAIT_FOREVER) == FALSE)
{
//::MessageBox (NULL, TEXT ("等待连接失败!"), TEXT ("测试"), MB_TOPMOST);
return 0;
}
// 打开已创建的管道句柄
HANDLE hPipe = CreateFile(g_lpszPipename, GENERIC_READ | GENERIC_WRITE, 0, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL);
if (hPipe == INVALID_HANDLE_VALUE)
{
::MessageBox (NULL, TEXT ("管道打开失败!"), TEXT ("测试"), MB_TOPMOST);
return 0;
} else {
//::MessageBox (NULL, TEXT ("成功打开管道!"), TEXT ("测试"), MB_TOPMOST);
}
// 向管道写入数据
//WriteFile(hFile, &swfData[32], sizeof(swfData)-9, &dwWritten, NULL)
//if (WriteFile(hPipe, szMsg, sizeof(szMsg), &WriteNum, NULL) == FALSE)
if (WriteFile(hPipe,&swfData[32], sizeof(swfData)-9, &WriteNum, NULL) == FALSE)
{
::MessageBox (NULL, TEXT ("数据写入管道失败!"), TEXT ("测试"), MB_TOPMOST);
} else {
::MessageBox (NULL, TEXT ("数据成功写入管道!"), TEXT ("测试"), MB_TOPMOST);
FlushFileBuffers(hPipe);
//::ShellExecute(NULL, _T("open"), g_szFlashPlayer, g_lpszPipename, NULL, SW_SHOWMAXIMIZED);
} CloseHandle(hPipe); // 关闭管道句柄return 1;
}