多线程 异步实现(通过事件驱动)
来源:互联网 发布:java jar 打包makefile 编辑:程序博客网 时间:2024/05/22 00:38
#include <windows.h>
#include <iostream.h>
DWORD WINAPI Fun1Proc(
LPVOID lpParameter // thread data
);
DWORD WINAPI Fun2Proc(
LPVOID lpParameter // thread data
);
//int index=0;
int tickets=100;
HANDLE g_hEvent;
void main()
{
HANDLE hThread1;
HANDLE hThread2;
hThread1=CreateThread(NULL,0,Fun1Proc,NULL,0,NULL);
hThread2=CreateThread(NULL,0,Fun2Proc,NULL,0,NULL);
CloseHandle(hThread1);
CloseHandle(hThread2);
/*while(index++<1000)
cout<<"main thread is running"<<endl;*/
g_hEvent=CreateEvent(NULL,FALSE,FALSE,NULL);
HANDLE hMutex=CreateMutex(NULL,TRUE,"tickets");
if(hMutex)
{
if(ERROR_ALREADY_EXISTS==GetLastError())
{
cout<<"only instance can run!"<<endl;
return;
}
}
WaitForSingleObject(hMutex,INFINITE);
ReleaseMutex(hMutex);/**/
// ReleaseMutex(hMutex);
SetEvent(g_hEvent);
Sleep(4000);
CloseHandle(g_hEvent);
// Sleep(10);
}
DWORD WINAPI Fun1Proc(
LPVOID lpParameter // thread data
)
{
/*while(index++<1000)
cout<<"thread1 is running"<<endl;*/
while(TRUE)
{
//ReleaseMutex(hMutex);
WaitForSingleObject(g_hEvent,INFINITE);
if(tickets>0)
{
Sleep(1);
cout<<"thread1 sell ticket : "<<tickets--<<endl;
}
else
break;
SetEvent(g_hEvent);
// ReleaseMutex(hMutex);
}
// WaitForSingleObject(hMutex,INFINITE);
// cout<<"thread1 is running"<<endl;
return 0;
}
DWORD WINAPI Fun2Proc(
LPVOID lpParameter // thread data
)
{
while(TRUE)
{
//ReleaseMutex(hMutex);
WaitForSingleObject(g_hEvent,INFINITE);
if(tickets>0)
{
Sleep(1);
cout<<"thread2 sell ticket : "<<tickets--<<endl;
}
else
break;
SetEvent(g_hEvent);
// ReleaseMutex(hMutex);
}
// WaitForSingleObject(hMutex,INFINITE);
// cout<<"thread2 is running"<<endl;
return 0;
}
#include <iostream.h>
DWORD WINAPI Fun1Proc(
LPVOID lpParameter // thread data
);
DWORD WINAPI Fun2Proc(
LPVOID lpParameter // thread data
);
//int index=0;
int tickets=100;
HANDLE g_hEvent;
void main()
{
HANDLE hThread1;
HANDLE hThread2;
hThread1=CreateThread(NULL,0,Fun1Proc,NULL,0,NULL);
hThread2=CreateThread(NULL,0,Fun2Proc,NULL,0,NULL);
CloseHandle(hThread1);
CloseHandle(hThread2);
/*while(index++<1000)
cout<<"main thread is running"<<endl;*/
g_hEvent=CreateEvent(NULL,FALSE,FALSE,NULL);
HANDLE hMutex=CreateMutex(NULL,TRUE,"tickets");
if(hMutex)
{
if(ERROR_ALREADY_EXISTS==GetLastError())
{
cout<<"only instance can run!"<<endl;
return;
}
}
WaitForSingleObject(hMutex,INFINITE);
ReleaseMutex(hMutex);/**/
// ReleaseMutex(hMutex);
SetEvent(g_hEvent);
Sleep(4000);
CloseHandle(g_hEvent);
// Sleep(10);
}
DWORD WINAPI Fun1Proc(
LPVOID lpParameter // thread data
)
{
/*while(index++<1000)
cout<<"thread1 is running"<<endl;*/
while(TRUE)
{
//ReleaseMutex(hMutex);
WaitForSingleObject(g_hEvent,INFINITE);
if(tickets>0)
{
Sleep(1);
cout<<"thread1 sell ticket : "<<tickets--<<endl;
}
else
break;
SetEvent(g_hEvent);
// ReleaseMutex(hMutex);
}
// WaitForSingleObject(hMutex,INFINITE);
// cout<<"thread1 is running"<<endl;
return 0;
}
DWORD WINAPI Fun2Proc(
LPVOID lpParameter // thread data
)
{
while(TRUE)
{
//ReleaseMutex(hMutex);
WaitForSingleObject(g_hEvent,INFINITE);
if(tickets>0)
{
Sleep(1);
cout<<"thread2 sell ticket : "<<tickets--<<endl;
}
else
break;
SetEvent(g_hEvent);
// ReleaseMutex(hMutex);
}
// WaitForSingleObject(hMutex,INFINITE);
// cout<<"thread2 is running"<<endl;
return 0;
}
- 多线程 异步实现(通过事件驱动)
- Future异步事件驱动
- 事件驱动异步模式
- 同步、异步、事件驱动
- 经典Demo(委托、事件、多线程、异步)
- Netty 基于事件驱动模型实现的异步IO
- I/0事件驱动实现异步curl,一
- vim通过事件驱动实现实时自动保存功能
- 【事件驱动】【数码管识别】(C++多线程实现多幅图像的同步识别)
- 事件驱动与异步IO
- C#多线程:异步事件调用
- 驱动实现异步通知
- 多线程异步实现(backgroundworker)
- ActiveX异步回调JavaScript(通过事件方式)
- ActiveX异步回调JavaScript(通过事件方式) .
- ActiveX异步回调JavaScript(通过事件方式)
- 微软开源P语言,实现安全的异步事件驱动编程
- 通过ESB构建事件驱动体系结构(一)
- java运算符优先级
- Linux设备驱动Hello World程序介绍
- Flash自定义事件
- ZipArchive 解压zip
- TCP/IP参考模型
- 多线程 异步实现(通过事件驱动)
- linux 中解析命令行参数(getopt_long用法)
- C语言文件操作函数详解
- VC知识库中关于多线程编程的文章
- iphone开发每日一练1【2011-09-30】
- BW性能监控利器——ST13总结
- 在UIView上添加一个导航栏
- 华为产品
- andorid 联系人 sim 增删改查