概述
这是程序员面试宝典中的一个例子,这里把其中的程序列写出来。
题目:
创建两个进程模拟火车站两个窗口售票程序,窗口售票时间为1s,两个窗口不能同时售票。
#include <iostream>
#include <string.h>
#include <Windows.h>
using namespace std;
DWORD WINAPI fun1proc(LPVOID lpParameter);
DWORD WINAPI fun2proc(LPVOID lpParameter);
int index = 0;
int tickets = 10;
HANDLE hMutex;
int main(int argc, char* argv[])
{
HANDLE hThread1;
HANDLE hThread2;
hThread1 = CreateThread(NULL, 0, fun1proc, NULL, 0, NULL);
hThread2 = CreateThread(NULL, 0, fun2proc, NULL, 0, NULL);
//create mutex
hMutex = CreateMutex(NULL, TRUE, NULL);
if (hMutex)
{
if (ERROR_ALREADY_EXISTS == GetLastError())
{
cout<<"Only one instance can run!"<<endl;
return 0;
}
}
WaitForSingleObject(hMutex, INFINITE);
ReleaseMutex(hMutex);
ReleaseMutex(hMutex);//???
Sleep(4000);
return 0;
}
DWORD WINAPI fun1proc(LPVOID lpParameter)
{
while(TRUE)
{
ReleaseMutex(hMutex);
WaitForSingleObject(hMutex,INFINITE);
if (tickets>0)
{
Sleep(1);
cout<<"thread1 sell ticket:"<<tickets--<<endl;
}
else
break;
ReleaseMutex(hMutex);
}
return 0;
}
DWORD WINAPI fun2proc(LPVOID lpParameter)
{
while(TRUE)
{
ReleaseMutex(hMutex);
WaitForSingleObject(hMutex, INFINITE);
if (tickets>0)
{
Sleep(1);
cout<<"Thread2 selling ticket: "<<tickets--<<endl;
}
else
break;
ReleaseMutex(hMutex);
}
return 0;
}
线程的初始化速度快,效率高,消耗资源少。所以多线程被广泛应用。
每个线程都要有一个进入点函数。
其中还可以使用互斥锁封锁其中需要修改的资源。
最后
以上就是秀丽蜗牛为你收集整理的(面试)多线程模拟火车站窗口售票程序。的全部内容,希望文章能够帮你解决(面试)多线程模拟火车站窗口售票程序。所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复