python司机和售票员的故事

1. 创建父子进程分别表示司机和售票员
2. 当售票员扑捉 SIGINT 信号时 ,发送SIGUSR1给司机,司机打印(‘发车了’)
   
当售票员捕捉到 SIGQUIT 信号时,发送SIGUSR2给司机,司机打印('停车')
   
司机捕捉到 SIGTSTP, 发送 SIGUSR1给售票员,
售票员打印(‘到站了 请下车’)
3.到站后司机等待售票员先下车,然后自己exit


温馨提示 : 当通过键盘发送信号时,会发送给终端的所有进程


汽车司机售票员之间必须协同工作,一方面,只有售票员把车门关好了司机才能开车,因此,售票员关好车门应通知司机开车。另一方面,只有当司机已经停 下,售票员才能开门上下客,故司机停车后应通知售票员。假定某辆公共汽车上有两名售票员与一名司机,汽车当前正在始发站停车上客,试设必要的信号灯及赋初值,写出他们的同步过程 分析: 司机停车,通知售票员开门,售票员关门,通知司机开车 使用到的函数和信号量 HANDLE mutex; HANDLE empty; HANDLE full; 创建信号量 HANDLE CreateSemaphore( __in_opt LPSECURITY_ATTRIBUTES lpSemaphoreAttributes,// lpSemaphoreAttributes是信号量的安全属性 可为NULL __in LONG lInitialCount,// lInitialCount是初始化的信号量 __in LONG lMaximumCount,// lMaximumCount是允许信号量增加到最大值 __in_opt LPCWSTR lpName//lpName是信号量的名称 可为NULL ); 创建互斥信号量 HANDLE CreateMutex(  LPSECURITY_ATTRIBUTES lpMutexAttributes, // 指向安全属性的指针 可为NULL  BOOL bInitialOwner, // 初始化互斥对象的所有者  LPCTSTR lpName // 指向互斥对象名的指针 ); 申请一个资源 WaitForSingleObject(HANDLE full,INFINITE); 释放资源 ReleaseSemaphore( __in HANDLE hSemaphore,// hSemaphore是要增加的信号量句柄 __in LONG lReleaseCount,// lReleaseCount是增加的计数。 __out_opt LPLONG lpPreviousCount//lpPreviousCount是增加前的数值返回。 ); 释放互斥信号量 BOOL ReleaseMutex(HANDLE hMutex); DWORD WaitForMultipleObjects( DWORD nCount, // number of handles in array CONST HANDLE *lpHandles, // object-handle array BOOL bWaitAll, // wait option DWORD dwMilliseconds // time-out interval );
#这只是一个半成品,只是实现了,一个完整的订票过程,对于,如果刷票,自己研究 #简单过程 # 第一、getRandAndCookie() 获得cook 和一个随机数用于登录 # 第二、getEnterRandCode() 得到登录时的识别码 # 第三、setuseandpassword(randcode,use,password) 发送随机数、识别码和用户及密码。由于随机数只在内部使用,所以定义成了全局变量, # 第四、GetTrainList() 得到所有车站列表,'@bjb|北京北|VAP|beijingbei|bjb|0' 其中有中文、拼音、拼音缩写、所一个ID(唯一),其主要是可以,通过上面的列表,找到它的唯一ID,TranCityToId('南昌') # 第五、GetTrainNumList(date,fromstationid,tostationid,starttime) 得到哪到哪的所在车次,消息格式如下,其中所以,一下车次的的ID:"id":"650000K1060I" # {"end_station_name":"北京西","end_time":"16:18","id":"650000K1060I","start_station_name":"深圳","start_time":"10:54","value":"K106"} # 通过ChangeToTrainNumId('K106')得到车次ID # 第六、QueryTrain(fromstationid,tostationid,date,stationNum,starttime) 就是点击查询按键,得到是否有能预订,格式如下 #       南昌         20:12,    北京西        07:38,11:26,--,--,--,--,10,有,有,--,有,有,--,<a name='btn130_2' class='btn130_2' # 通过choiceSubmitNum(stationNum,trainsubmitinfo)提取出getSelected()消息 # 第七、submitRequest(choiceSubmitNum(stationNum,trainsubmitinfo),date,starttime) 就是点击预订按钮 # 第八、getrandCheckCode()得到提交订单的识别码 # 第十、CheckInMyTicket(info,randcode,peoples)点击提交,如果成功的话,就会返回{"errMsg":"Y"} # 出于,网络是UTF8格式,所以,必须# -*- coding: utf-8 -*-,(当然,自己转换也是可以的) # 出于这一个控制台信息,所以,识别码的图片在脚本同一目录 #得到头信息
假设有一个公交车的售票员司机需要进行同步操作,售票员需要在每一站点停车后向乘客售票,而司机则需要等待售票员售票完成后才能继续行驶。 我们可以使用线程和信号量机制来实现这个同步操作问题。具体实现步骤如下: 1. 创建两个线程,一个线程代表售票员,一个线程代表司机。 2. 创建一个信号量,初始值为0,用于表示售票员是否已经完成售票操作。 3. 在售票员线程中,售票员首先等待司机发出停车信号。一旦司机发出停车信号售票员开始售票操作,售票员售票完成后释放信号量。 4. 在司机线程中,司机首先行驶到下一站点,然后发出停车信号,等待售票员完成售票操作,一旦售票员完成售票操作,司机释放售票信号量并继续行驶。 代码示例: ```python import threading ticket_semaphore = threading.Semaphore(0) def driver(): while True: # 行驶到下一站点 print("Driver: Next stop.") # 发出停车信号 ticket_semaphore.release() # 等待售票员完成售票操作 ticket_semaphore.acquire() # 继续行驶 print("Driver: Continue driving.") def conductor(): while True: # 等待司机发出停车信号 ticket_semaphore.acquire() # 售票员开始售票操作 print("Conductor: Selling tickets.") # 售票员售票完成 ticket_semaphore.release() driver_thread = threading.Thread(target=driver) conductor_thread = threading.Thread(target=conductor) driver_thread.start() conductor_thread.start() ``` 在这个示例中,售票员司机使用一个信号量进行同步操作,售票员在完成售票操作后释放信号量,司机在发出停车信号后等待售票员完成售票操作并释放信号量。这样就可以保证售票员司机的操作是同步的。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值