c++

博客园 首页 新随笔 联系 订阅 管理

2011年3月8日 #

摘要: PJSIP是一个开放源代码的SIP协议栈。它支持多种SIP的扩展功能,目前可说算是最流行的sip协议栈之一了。下面列出其重要的几种优点:1)代码层次非常清晰,从低级到高级都提供了很方便的接口供开发;2)提供相当多的测试用例和一个基于pjsip开发的命令行UA程序供开发人员参考;3).高度的可移殖性 只需简单的编译一次,它能够在多种平台上运行(所有Windows 系统列, Windows Mobile, Linux, 所有Unix 系列, MacOS X, RTEMS, Symbian OS, 等等)。 4).极小的内存需求 官方宣称编译后的库,完全实现SIP的功能只需要150K的内存空间,这使 阅读全文
posted @ 2011-03-08 10:32 lovewcl 阅读(1317) 评论(0) 推荐(0) 编辑

2011年3月7日 #

摘要: 下面这段程序是一个C语言的小技巧,其展示了如何把一个参数为结构体的函数转成一个可变参数的函数,其中用到了宏和内建宏“__VA_ARGS__”,下面这段程序可以在GCC下正常编译通过:#include <stdio.h> #define func(...) myfunc((struct mystru){__VA_ARGS__}) struct mystru { const char *name; int number; }; void myfunc( struct mystru ms ){ printf ( "%s: %d/n" , ms.name ?: &quo 阅读全文
posted @ 2011-03-07 23:21 lovewcl 阅读(243) 评论(0) 推荐(0) 编辑

2011年3月4日 #

摘要: 十一过后..小王也刚好即将大学毕业,现在要开始写简历,投简历,找工作了。到了家工作单位,小王欣喜若狂,可再一看,心都凉了半截..“咋了,小王,看你找工作,我都来了帮你大气,怕什么,不就人多点吗..”看着排到电梯口的长龙,我说(其实,我心里也害怕,可也不能说出来不是)。“不是,你不知道,我并不怕面试上有问题,有你在,技术上还是问题吗,不相信自己还不相信你啊,我主要是怕连面试的机会都没有,你看那么多人,不知道要排到哪里去了,你说每年都这样,那些人力主管部门的咋也不想个好办法来改善一下..”小王抱怨道。“呵呵,有需求才会有进步”我哈哈大笑道,“要不这样吧,看这样子,正好给你说说有关Linux设备驱动 阅读全文
posted @ 2011-03-04 16:57 lovewcl 阅读(698) 评论(0) 推荐(1) 编辑

2011年3月3日 #

摘要: 信号量当我们在多用户系统,多进程系统,或是两者混合的系统中使用线程操作编写程序时,我们经常会发现我们有段临界代码,在此处我们需要保证一个进程(或是一个线程的执行)需要排他的访问一个资源。信号量有一个复杂的编程接口。幸运的是,我们可以很容易的为自己提供一个对于大多数的信号量编程问题足够高效的简化接口。为了阻止多个程序同时访问一个共享资源所引起的问题,我们需要一种方法生成并且使用一个标记从而保证在临界区部分一次只有一个线程执行。线程相关的方法,我们可以使用互斥或信号量来控制一个多线程程序对于临界区的访问。编写通用目的的代码保证一个程序排他的访问一个特定的资源是十分困难的,尽管有一个名为Dekker 阅读全文
posted @ 2011-03-03 19:39 lovewcl 阅读(45213) 评论(1) 推荐(1) 编辑

摘要: 1. #include <sys/stat.h> 2. #include <fcntl.h> 3. #include <sys/mman.h> 4. #include <unistd.h> 5. 6. 7. #include <pthread.h> 8. #include <stdio.h> 9. #include <stdlib.h> 10. 11. 12. 13. 14. int main(void){//2个进程,一个进程完成每次加1,另一个进程完成每次加2,2个进程协作完成累... 阅读全文
posted @ 2011-03-03 18:36 lovewcl 阅读(4587) 评论(1) 推荐(0) 编辑

摘要: #include <sys/ipc.h>#include <sys/shm.h>int shmget(key_t key, size_t size, int shmflg); key_t key key标识共享内存的键值: 0/IPC_PRIVATE。 当key的取值为IPC_PRIVATE,则函数shmget()将创建一块新的共享内存;如果key的取值为0,而参数shmflg中设置了IPC_PRIVATE这个标志,则同样将创建一块新的共享内存。在IPC的通信模式下,不管是使用消息队列还是共享内存,甚至是信号量,每个IPC的对象(object)都有唯一的名字,称为“键” 阅读全文
posted @ 2011-03-03 15:55 lovewcl 阅读(1193) 评论(0) 推荐(0) 编辑

摘要: 根据pathname指定的文件(或目录)名称,以及proj_id参数指定的数字,ftok函数为IPC对象生成一个唯一性的键值。在实际应用中,很容易产生的一个理解是,在proj_id相同的情况下,只要文件(或目录)名称不变,就可以确保ftok返回始终一致的键值。然而,这个理解并非完全正确,有可能给应用开发埋下很隐晦的陷阱。因为ftok的实现存在这样的风险,即在访问同一共享内存的多个进程先后调用ftok函数的时间段中,如果pathname指定的文件(或目录)被删除且重新创建,则文件系统会赋予这个同名文件(或目录)新的i节点信息,于是这些进程所调用的ftok虽然都能正常返回,但得到的键值却并不能保证 阅读全文
posted @ 2011-03-03 15:14 lovewcl 阅读(7421) 评论(0) 推荐(1) 编辑

摘要: 在System V中,我们经常用用key_t的值来创建或者打开信号量,共享内存和消息队列。这个在IPC的环境中十分的重要,比如说,服务器创建了一个消息队列,等待客户机发送请求。那么如何创建或者打开已有的消息队列呢?一般而言,我们对于服务器使用的路径和项目id(proj_id)是已知的,所以客户机可以获取相同的key来打开 消息队列并进行操作。下面就是ftok的使用原型:# include <sys/types.h># include <sys/ipc.h>key_t ftok(const char *pathname, int proj_id);注意:1)path... 阅读全文
posted @ 2011-03-03 15:08 lovewcl 阅读(494) 评论(0) 推荐(0) 编辑

摘要: 共享内存的函数有以下几个:(1)int shmget(key_t key, int size, int shmflg),开辟或使用一块共享内存。(2)void *shmat(int shmid, const void *shmaddr, int shmflg), 将参数shmid所指向的共享内存与当前进程连接。当使用某共享内存时,需要先使用shmat,达成连接。(3)int shmdt(const void *shmaddr),将先前用shmat连接的共享内存与当前进程解除连接。参数shmaddr为shmat返回的共享内存的地址。在完成对共享内存的使用后,需要使用shmdt解除连接。(4)in 阅读全文
posted @ 2011-03-03 14:32 lovewcl 阅读(836) 评论(0) 推荐(0) 编辑

2011年2月24日 #

摘要: 线程(thread)技术早在60年代就被提出,但真正应用多线程到操作系统中去,是在80年代中期,solaris是这方面的佼佼者。传统的Unix也支持线程的概念,但是在一个进程(process)中只允许有一个线程,这样多线程就意味着多进程。现在,多线程技术已被许多操作系统所支持,包括Windows/NT,当然,也包括Linux。 为什么有了进程的概念后,还要再引入线程呢?使用多线程到底有哪些好处?什么的系统应该选用多线程?我们首先必须回答这些问题。 使用多线程的理由之一是和进程相比,他是一种很"节俭"的多任务操作方式。我们知道,在Linux系统下,启动一个新的进程必须分配给他 阅读全文
posted @ 2011-02-24 10:41 lovewcl 阅读(1834) 评论(0) 推荐(0) 编辑