仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 696|回复: 9
打印 上一主题 下一主题

[其他Linux] 给大家带来Linux旌旗灯号量编程实例

[复制链接]
简单生活 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-1-16 12:58:28 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
如果你让他去用linux搭建一个web服务器,做一个linux网关,他就什么都不会了.他们把时间都浪费在了版本的转换上了.
本例树模Linux旌旗灯号量的基础用法。该典范利用了两个线程分离对一个公用行列举行进队和出队操纵,并用旌旗灯号量举行把持,当行列空时出队操纵能够被堵塞,当行列满时进队操纵能够被堵塞。
次要用到的旌旗灯号量函数有:
sem_init:初始化旌旗灯号量sem_t,初始化的时分能够指定旌旗灯号量的初始值,和是不是能够在多历程间共享。
sem_wait:一向堵塞守候直到旌旗灯号量>0。
sem_timedwait:堵塞守候多少工夫直到旌旗灯号量>0。
sem_post:使旌旗灯号量加1。
sem_destroy:开释旌旗灯号量。和sem_init对应。
关于各函数的详细参数请用man检察。如mansem_init可检察该函数的匡助。
上面看详细的代码:
//--------------------------msgdequeue.h入手下手-------------------------------------
//完成可控行列
#ifndefMSGDEQUEUE_H
#defineMSGDEQUEUE_H
#include"tmutex.h"
#include<iostream>
#include<errno.h>#include<time.h>#include<semaphore.h>
#include<deque>
usingnamespacestd;
template<typenameT,typenameMUTEX_TYPE=ThreadMutex>
classCMessageDequeue
{
public:
CMessageDequeue(size_tMaxSize):m_MaxSize(MaxSize)
...{sem_init(&m_enques,0,m_MaxSize);//进队旌旗灯号量初始化为MaxSize,最多可包容MaxSize各元素sem_init(&m_deques,0,0);//行列刚入手下手为空,出队旌旗灯号量初始为0
}
~CMessageDequeue()
...{
sem_destroy(&m_enques);
sem_destroy(&m_deques);
}
intsem_wait_i(sem_t*psem,intmswait)...{//守候旌旗灯号质变成>0,mswait为守候工夫,若mswait<0则无量守候,不然守候多少mswait毫秒。
if(mswait<0)
...{
intrv=0;
while(((rv=sem_wait(psem))!=0)&&(errno==EINTR));//守候旌旗灯号量,errno==EINTR屏障其他旌旗灯号事务引发的守候中止
returnrv;
}
else
...{
timespects;
clock_gettime(CLOCK_REALTIME,&ts);//猎取以后工夫ts.tv_sec+=(mswait/1000);//加上守候工夫的秒数ts.tv_nsec+=(mswait%1000)*1000;//加上守候工夫纳秒数
intrv=0;
while(((rv=sem_timedwait(psem,&ts))!=0)&&(errno==EINTR));//守候旌旗灯号量,errno==EINTR屏障其他旌旗灯号事务引发的守候中止
returnrv;
}
}
boolpush_back(constT&item,intmswait=-1)...{//守候mswait毫秒直到将item拔出行列,mswait为-1则一向守候if(-1
123下一页


功能实在太强了,在配合exec参数或者通过管道重定向到xargs命令和grep命令,可以完成非常复杂的操作,如果同样的操作用图形界面的工具来完成,恐怕要多花十几陪的时间。
简单生活 该用户已被删除
沙发
 楼主| 发表于 2015-1-16 13:02:55 | 只看该作者

给大家带来Linux旌旗灯号量编程实例

Linux的常用命令find,察看man文档,初学者一定会觉得太复杂而不原意用,但是你一旦学会就爱不释手。
==sem_wait_i(&m_enques,mswait))...{</P>returnfalse;
}
//AUTO_GUARD:定界加锁,见Linux多线程及临界区编程例解的tmutex.h文件界说。
AUTO_GUARD(g,MUTEX_TYPE,m_lock);
try
...{m_data.push_back(item);
cout<<"push"<<item<<endl;
sem_post(&m_deques);
returntrue;
}
catch(...)...{
returnfalse;
}
}
boolpop_front(T&item,boolbpop=true,intmswait=-1)...{//守候mswait毫秒直到从行列掏出元素,mswait为-1则一向守候if(-1==sem_wait_i(&m_deques,mswait))...{
returnfalse;
}
//AUTO_GUARD:定界加锁,见Linux多线程及临界区编程例解的tmutex.h文件界说。
AUTO_GUARD(g,MUTEX_TYPE,m_lock);
try
...{item=m_data.front();
if(bpop)
...{m_data.pop_front();
cout<<"pop"<<item<<endl;
}
sem_post(&m_enques);
returntrue;
}
catch(...)...{
returnfalse;
}
}
inlinesize_tsize()
...{returnm_data.size();
}
private:
MUTEX_TYPEm_lock;
deque<T>m_data;
size_tm_MaxSize;
sem_tm_enques;
sem_tm_deques;
};
#endif
//--------------------------msgdequeue.h停止-------------------------------------
//--------------------------test.cpp入手下手-------------------------------------
//主程叙文件
#include"msgdequeue.h"#include<pthread.h>
#include<iostream>
usingnamespacestd;
CMessageDequeue<int>qq(5);
void*get_thread(void*parg);
void*put_thread(void*parg);
void*get_thread(void*parg)
{
while(true)
...{
inta=-1;
if(!qq.pop_front(a,true,1000))...{cout<<"popfailed.size="<<qq.size()<<
上一页123下一页


功能实在太强了,在配合exec参数或者通过管道重定向到xargs命令和grep命令,可以完成非常复杂的操作,如果同样的操作用图形界面的工具来完成,恐怕要多花十几陪的时间。
简单生活 该用户已被删除
板凳
 楼主| 发表于 2015-1-16 13:18:13 | 只看该作者

给大家带来Linux旌旗灯号量编程实例

学习python,无论你是打算拿他当主要开发语言,还是当辅助开发语言,你都应该学习他,因为有些时间我们耗不起。
endl;</P>}
}
returnNULL;
}
void*put_thread(void*parg)
{
for(inti=1;i<=30;i++)
...{qq.push_back(i,-1);
}
returnNULL;
}
intmain()
{
pthread_tpget,pput;pthread_create(&pget,NULL,get_thread,NULL);
pthread_create(&pput,NULL,put_thread,NULL);
pthread_join(pget,NULL);pthread_join(pput,NULL);
return0;
}
//--------------------------test.cpp停止-------------------------------------............编译程序:g++msgdequeue.htest.cpp-lpthread-lrt-otest-lpthread链接pthread库。-ltr链接clock_gettime函数相干库。
编译后天生可实行文件test。输出./test实行程序。
线程get_thread每隔1000毫秒从行列取元素,线程put_thread将30个元素顺次进队。两个线程摹拟两条进队和出队的流水线。因我们在CMessageDequeue<int>qq(5)处界说了行列最多可包容5个元素,进队线程每进队到行列元素满5个后需堵塞守候出队线程将行列元素出队才干持续。测试时可调剂行列可包容最年夜元素个数来察看运转效果。
</p>
上一页123


对于开发环境的选择尽量要轻量级和高度可定制,航空母舰级别的工具往往会让你迷惑不解;
莫相离 该用户已被删除
地板
发表于 2015-1-18 16:45:09 | 只看该作者
甚至目前许多应用软件都是基于它的。可是没有哪一个系统是十分完美的。
金色的骷髅 该用户已被删除
5#
发表于 2015-1-27 12:27:01 | 只看该作者
清楚了解网络的基础知识,特别是在Linux下应用知识,如接入internet等等。
山那边是海 该用户已被删除
6#
发表于 2015-2-5 13:20:04 | 只看该作者
任何人都可以根据自己的喜好来定制适合自己的操作系统,Linux?是抢占式多任务多用户操作系统.
小妖女 该用户已被删除
7#
发表于 2015-2-12 01:50:13 | 只看该作者
生成新的unispimsp.ksc。”另外得到回复后如果问题解决,向帮助过你的人发个说明,让他们知道问题是怎样解决的。
小魔女 该用户已被删除
8#
发表于 2015-3-2 22:03:29 | 只看该作者
请问谁有Linux的学习心得的吗?简单的说说?
因胸联盟 该用户已被删除
9#
发表于 2015-3-11 08:28:53 | 只看该作者
你需要提供精确有效的信息。Linux这并不是要求你简单的把成吨的出错代码或者数据完全转储摘录到你的提问中。
小女巫 该用户已被删除
10#
发表于 2015-3-25 17:45:53 | 只看该作者
熟读写基础知识,学得会不如学得牢。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2025-1-23 05:03

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表