VS2010 多线程 进程互斥
来源:百度文库 编辑:神马文学网 时间:2024/05/04 03:04:24
#include
#include
#include
using namespace std;
DWORD WINAPI Fun1Proc(
LPVOID lpParameter // thread data
);DWORD WINAPI Fun2Proc(
LPVOID lpParameter // thread data
);
int index=0;
int tickets=100;
HANDLE hMutex;
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);
hMutex=CreateMutex(NULL,false,_T("tickets"));//第二个变量为true时当前线程拥有互斥对象的所有权,否则不拥有
if(hMutex)
{
if(ERROR_ALREADY_EXISTS==GetLastError())
{
cout<<"only instance can run!"< return;
}
}
/*WaitForSingleObject(hMutex,INFINITE);
ReleaseMutex(hMutex);
ReleaseMutex(hMutex);*/
Sleep(4000);//主线程放弃执行权4s
}DWORD WINAPI Fun1Proc(
LPVOID lpParameter // thread data
)
{
while(TRUE)//线程1,一直执行
{
WaitForSingleObject(hMutex,INFINITE);//请求互斥对象所有权
if(tickets>0)
{
//Sleep(1);
cout<<"thread1 sell ticket : "< }
else
break;
ReleaseMutex(hMutex););//释放互斥对象所有权
} return 0;
}DWORD WINAPI Fun2Proc(
LPVOID lpParameter // thread data
)
{
while(TRUE)
{
//ReleaseMutex(hMutex);
WaitForSingleObject(hMutex,INFINITE);
if(tickets>0)
{
//Sleep(1);
cout<<"thread2 sell ticket : "< }
else
break;
ReleaseMutex(hMutex);
}
return 0;
} 说明,在一个子线程结束时,该线程所对应的请求的互斥对象都会被自动释放,且请求的互斥对象句柄也被置为0。
#include
#include
using namespace std;
DWORD WINAPI Fun1Proc(
LPVOID lpParameter // thread data
);DWORD WINAPI Fun2Proc(
LPVOID lpParameter // thread data
);
int index=0;
int tickets=100;
HANDLE hMutex;
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);
hMutex=CreateMutex(NULL,false,_T("tickets"));//第二个变量为true时当前线程拥有互斥对象的所有权,否则不拥有
if(hMutex)
{
if(ERROR_ALREADY_EXISTS==GetLastError())
{
cout<<"only instance can run!"<
}
}
/*WaitForSingleObject(hMutex,INFINITE);
ReleaseMutex(hMutex);
ReleaseMutex(hMutex);*/
Sleep(4000);//主线程放弃执行权4s
}DWORD WINAPI Fun1Proc(
LPVOID lpParameter // thread data
)
{
while(TRUE)//线程1,一直执行
{
WaitForSingleObject(hMutex,INFINITE);//请求互斥对象所有权
if(tickets>0)
{
//Sleep(1);
cout<<"thread1 sell ticket : "<
else
break;
ReleaseMutex(hMutex););//释放互斥对象所有权
} return 0;
}DWORD WINAPI Fun2Proc(
LPVOID lpParameter // thread data
)
{
while(TRUE)
{
//ReleaseMutex(hMutex);
WaitForSingleObject(hMutex,INFINITE);
if(tickets>0)
{
//Sleep(1);
cout<<"thread2 sell ticket : "<
else
break;
ReleaseMutex(hMutex);
}
return 0;
} 说明,在一个子线程结束时,该线程所对应的请求的互斥对象都会被自动释放,且请求的互斥对象句柄也被置为0。
VS2010 多线程 进程互斥
多线程编程浅析 -- 多线程的互斥与同步
PHP中的(伪)多线程与多进程
LoadRunner中的多进程和多线程
VS2010 静态编译
linux下多进程、多线程编程 - 技术文档 - 程序开发 Linux时代 - 开源、自由...
内核中的互斥之我见
防止程序重复运行(互斥方式)
防止程序重复运行(互斥方式)
Linux多线程 Linux多线程
java多线程
多线程错误
python 多线程
多线程编程
多线程编程
多线程编程
Windows线程同步与互斥技术总结
Windows线程同步与互斥技术总结
再谈 Windows 窗体多线程
Java多线程程序设计
多线程的测试
Java5 多线程实践
Java多线程编程总结
Java多线程设计要点