码迷,mamicode.com
首页 > 系统相关 > 详细

Linux C 程序 进程间通信(20)

时间:2015-01-09 13:57:10      阅读:206      评论:0      收藏:0      [点我收藏+]

标签:

进程间通信

1.进程间通信的几种手段:
    (1).管道
        数据只能由一个进程流向另一个进程(其中一个读管道,一个写管道),如果要建立全双工通信,需要建立两个管道
        只能用于父子,兄弟(有亲缘关系的进程)间通信
    (2).有名管道
        (named pipe ,FIFO)克服了管道的限制,可用于无亲缘关系的进程通信
        有名管道是一个设备文件
        FIFO原则,第一个被写入的数据,第一个被读出
    (3).信号量
        一个计数器,常用于进程和线程间同步问题,特别对临界资源的访问
        临界资源可以理解为某时刻只能由一个线程或者进程访问的资源
        信号量大于或者等于0可供并发使用的资源实体数,小于0代表正在等待使用临界资源的进程数
    (4).消息队列
        存放内核的一个消息列表,由消息列队标识符标识,只有内核重启或者显示删除一个队列,消息列队才会被真正删除。
        消息列队用到一些数据结构:
            消息缓冲结构
            mspid_ds内核数据结构
            ipc_perm内核数据结构
    (5).信号
    (6).共享内存
        共享内存就是分配一块能被其他进程访问的内存。每个共享内存段在内核中维护着一个内部结构shmid_ds(和消息队列和信号量一样)    
    (7).套接字
        
        
2.库的创建和使用
    Windows系统本身提供并使用了大量的库,包括静态链接库(lib文件),动态链接库(dll文件)
    类似:linux也使用库,Linux下通常把库文件存放在/usr/lib或者/lib下
    Linux库文件由前缀lib,库名和后缀组成。
    动态库以.so作为后缀,静态库以.a作为后缀
    程序中使用静态链接库和动态链接库时,他们的载入顺序不一样。
    静态库的代码在编译时就拷贝到应用程序中,当多个程序调用一个静态链接库时,内存中会有多个函数的副本。优点:节省编译时间。
    动态库在程序开始运行后调用函数库时才被载入,被调函数在内存中只有一个副本。并且动态库可在程序运行期间释放动态库占用的内存。
        从编写库函数,编译生成库文件,调用库函数3方面介绍静态,动态库:
        1.静态库的创建和使用:
            (1).在一个头文件中声明静态库所导出的函数
            (2).在一个源文件中实现静态库所导出的函数
            (3).编译源文件,生成可执行代码
            (4).将可执行代码所在的目标文件加入到某静态库中,并将静态库存放在系统默认的存放库文件的目录下。
 1 编译生成目标文件:gcc -o mylib.o -c mylib.c

2 将目标文件加入到静态库中,ar rcs libmylib.a mylib.o 
            将静态库拷贝到Linux库目录(usr/lib或/lib)
            
            用到静态库编译程序:gcc -o test test.c -lmylib
        2.动态链接库的创建和使用:
 1 gcc -fPIC -o mylib.o -c mylib.c

2 gcc -shared -o libttt.so mylib.o 
            
            合并成一条
 1 gcc -fPIC -shared -o libttt.so mylib.c 
            
用动态链接库编译自己程序:
 1 gcc -o main main.c ./libmylib.so

2 或者

3 cp libttt.so /usr/lib/libttt.so

4 gcc -o test test.c /usr/lib/libttt.so 
            使用动态链接库时必须含有路径,如果只用 libttt.so则必须确保这个库在环境变量路径中
            
            方法二调用动态链接库:
            调用linux系统函数实现
             dlopen ,dlsym , dlclose ,dlerror
            
            
            下一步学习书籍:Unix环境高级编程 ,Solaris系统编程,深入理解Linux内核
            
            
        
            
    
            
        
        
    

















Linux C 程序 进程间通信(20)

标签:

原文地址:http://www.cnblogs.com/fubinhnust/p/4213012.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!