本篇内容介绍了“QT互斥量怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
创新互联是一家集网站建设,邵东企业网站建设,邵东品牌网站建设,网站定制,邵东网站建设报价,网络营销,网络优化,邵东网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。
访问同一数据的多个任务(线程)的代码随机交替执行,是任务(线程)间数据交换不能正常进行的原因。那么对策就显而易见:想办法让访问同一段数据的代码不会同时(时间上有交叉)执行即可。
其实也说不上想办法,因为操作系统已经将这种机制准备好了:mutex(互斥量)
互斥量实例(QT环境)
执行结果
今天换个顺序,先看执行结果。
WT:<<<
WT:{
WT: if(m_dataSize < (ARRAY_SIZE - 1))
WT: {
WT: m_buffer[0] = 0;
WT: m_dataSize++;
WT: }
WT:}
WT:int DataArray::addData(1)
WT:{
WT: if(m_dataSize < (ARRAY_SIZE - 1))
WT: {
WT: m_buffer[1] = 1;
WT: m_dataSize++;
WT: }
WT:}
WT:int DataArray::addData(2)
WT:{
WT: if(m_dataSize < (ARRAY_SIZE - 1))
WT: {
WT: m_buffer[2] = 2;
WT: m_dataSize++;
WT: }
WT:}
WT:int DataArray::addData(3)
WT:{
WT: if(m_dataSize < (ARRAY_SIZE - 1))
WT: {
WT: m_buffer[3] = 3;
WT: m_dataSize++;
WT: }
WT:}
WT:int DataArray::addData(4)
WT:{
WT: if(m_dataSize < (ARRAY_SIZE - 1))
WT: {
WT: m_buffer[4] = 4;
WT: m_dataSize++;
WT: }
WT:}
RT:>>>>ReadData:8>>>>
RT:int DataArray::getDataSize()
RT:{
RT: return 5;
RT:}
RT::----data_size=5
RT:int DataArray::getData(0)
RT:{
RT: if(index >= 0 && index < m_dataSize)
RT: {
RT: return m_buffer[0]RT: }
RT:}
RT:int DataArray::getData(1)
RT:{
RT: if(index >= 0 && index < m_dataSize)
RT: {
RT: return m_buffer[1]RT: }
RT:}
RT:int DataArray::getData(2)
RT:{
RT: if(index >= 0 && index < m_dataSize)
RT: {
RT: return m_buffer[2]RT: }
RT:}
RT:int DataArray::getData(3)
RT:{
RT: if(index >= 0 && index < m_dataSize)
RT: {
RT: return m_buffer[3]RT: }
RT:}
RT:int DataArray::getData(4)
RT:{
RT: if(index >= 0 && index < m_dataSize)
RT: {
RT: return m_buffer[4]RT: }
RT:}
RT:----total=10
可以很明显的看出:读和写之间没有任何交叉,当然这时的结果就是对的了。
代码
首先在46行创建QMutex对象。
CreatDataTask从48行到68行,是一个内嵌类。57行增加了一个引用类型的私有数据成员m_mutex。实际的对象是在73行调用51行的构造函数时传进来的。在62行访问数据之前调用lock方法,在65行访问数据结束后调用unlock方法。
读数据是在主函数中进行,它也是一个线程。同样地,访问数据之前调用lock方法,访问数据之后调用unlock方法。
“QT互斥量怎么实现”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注创新互联网站,小编将为大家输出更多高质量的实用文章!