线程学习笔记(2)-互斥对象
来源:互联网 发布:淘宝分销平台 编辑:程序博客网 时间:2024/05/17 01:20
1)互斥对象的概念:互斥对象是系统内核维护的一种数据结构,它定保证了对象对单个线程的访问权
互斥对象的结构:包含了一个使用数量,一个线程ID,一个计数器
使用数量是指有多少个线程在调用该对象,线程ID是指互斥对象维护的线程的ID
计数器表示当前线程调用该对象的次数
2)互斥对象的创建】
HANDLE CreateMutex( LPSECURITY_ATTRIBUTES lpMutexAttributes,//安全性 BOOL bInitialOwner,//初始的拥有者,要是FALSE则初始没有拥有者 LPCTSTR lpName//设置互斥对象的名字);
3)获得互斥对象
DWORD WaitForSingleObject( HANDLE hHandle,//互斥对象的句柄 DWORD dwMilliseconds//Time-out interval, in milliseconds.//The function returns if the interval elapses,//even if the object's state is nonsignaled.//If dwMilliseconds is zero, the function tests the object's state and returns immediately.//If dwMilliseconds is INFINITE, the function's time-out interval never elapses. );如果第二个参数是0,则是测试对象的状态后立即返回
如果是INFINITE,则一直测试对象状态直到接受到信号
4)释放互斥对象
如果一个线程拥有了一个互斥对象后,当该线程运行完成后就要释放该互斥对象,不如其他的线程得不到互斥对象则无法运行
用ReleaseMutex(HWND);操作
下面是代码
#include <windows.h>
#include <iostream.h>
DWORD WINAPI Fun1Pro(LPVOID lpParameter);
DWORD WINAPI Fun2Pro(LPVOID lpParameter);
//int index=1000;
int ticket=1000;
HANDLE hMutex;
void main()
{
HANDLE hThread1;
HANDLE hThread2;
hThread1=CreateThread(NULL,0,Fun1Pro,NULL,0,NULL);
hThread2=CreateThread(NULL,0,Fun2Pro,NULL,0,NULL);
CloseHandle(hThread1);
CloseHandle(hThread2);
hMutex=CreateMutex(NULL,FALSE,NULL);
Sleep(4000);
/*for(index;index>0;index--)
{
cout<<"main thread run"<<endl;
//Sleep(10);
}*/
}DWORD WINAPI Fun1Pro(LPVOID lpParameter)
{ //while(index>0)
//cout<<"thread2 is run............................................"<<endl;
while(true)
{
WaitForSingleObject(hMutex,INFINITE);
if(ticket>0)
{
Sleep(1);
cout<<"num one sale ticket:"<<ticket--<<"sale"<<endl;
}
else
break;
ReleaseMutex(hMutex);
}
return 0;
}
DWORD WINAPI Fun2Pro(LPVOID lpParameter)
{
while(true)
{
WaitForSingleObject(hMutex,INFINITE);
if(ticket>0)
{
Sleep(1);
cout<<"num two sale ticket:--------------"<<ticket--<<"sale"<<endl;
}
else
break;
ReleaseMutex(hMutex);
}
return 0;
}
这里还有个问题一直不明白
在这里加上Sleep后线程一和线程二才是交替运行
if(ticket>0)
{
Sleep(1);
cout<<"num two sale ticket:--------------"<<ticket--<<"sale"<<endl;
}
当去掉Sleep后,一个线程运行多次后才运行第二个线程
个人认为加上加上Sleep后时间片用完了
所以下一个进程接着运行
- 线程学习笔记(2)-互斥对象
- 线程学习笔记(2)-互斥对象
- 线程2:互斥对象
- 线程(使用互斥对象)
- Java线程学习笔记(三)---线程同步互斥
- POSIX线程:互斥对象
- 线程同步-互斥对象
- 《windows核心编程学习笔记》——使用互斥量变量内核对象进行线程同步
- 学习笔记一:使用Mutex实现线程之间互斥
- java 多线程学习笔记之 线程互斥
- 【Java学习笔记】15:线程的共享互斥
- windows笔记-【内核对象线程同步】互斥对象内核对象
- 线程同步中的互斥对象(转帖)
- 线程同步之互斥对象(通俗易懂)
- 线程的同步互斥之事件对象(Event)
- 线程同步互斥之信号量对象(Semaphore)
- 线程学习之线程互斥
- 线程学习之--传统线程互斥
- JBoss, Inc. Launches JBoss Open Source Federation
- 外贸英语900句之 对外贸易与外贸关系
- showModalDialog()、showModelessDialog()方法使用详解
- 网页中META标签的使用
- 用户如何有效地利用数据字典
- 线程学习笔记(2)-互斥对象
- 如何实现大图标风格的打开对话框
- (转)图片上传并生成缩略图
- 对象的生存空间
- 我想学好C#怎么办
- 即将开始游戏引擎的开发学习了
- 网址收藏
- C#2.0 Partial 特性
- mysql实际操作