精通UNIX下C语言编程与项目实践
2013-08-23 21:41
183 查看
cc
-I //include 目录
-L //静态库目录?动态也可以
-l //小写L,接静态库名称?动态也可以
-DXXX=‘“XXFF”’ //-D直接定义宏
-c 只编译
-O 优化
-g 生成调试信息
splint , gprof, cflow , dbx , gdb ,sdb //除了工具,还有日志记录调试更便捷
动态库:隐式调用 自动加载,与静态库一致 使用时,cc 后面加上路径,接口不变可以直接换so文件
显示调用 用dlopen
动态库创建:位置无关码(PIC)型.o
gcc -O -shared -shared -o xxx.so xxx.c
LD_LIBRARY_PATH //LINUX下设置这个环境目录,放动态库
#include <dlfcn.h> dlopen() / dlsym()
显示调用动态库流程
gcc -O -o tds tds.c -ldl //-ldl 固定写法 显示调用动态库时用
二、文件系统
超级块结构 filsys.h ; i node ino.h ;文件属性 stat.h ;
termio.h struct termio ioctl()
三、并发程序设计
sysproc //标识号0 调度系统中运行的进程, init // 标识号为1
geteuid() 进程有效用户ID,getegid() 进程有效组ID
fork-exec;vfork-exec模型
system() == vfork-exec
wait 实现父子进程之间同步:函数wait挂起调用它的进程,直到它的任一子进程退出
waitpid wait加强版 <sys/wait.h>
避免僵死进程 :fork两次让子进程退出,子子进程的父进程更改为进程init
四、进程通信
popen() pclose
mkfifo/mknod k1 p 有名管道用文件操作调用使用
消息对列是UNIX内核中一个先进先出链表结构
狭义讲IPC特指消息对列,信号量,共享内存
ipc /ipcrm <sys/msg.h> struct msqid_qs
int msgget(key_t key,int msgflg); //创建消息队列
msgsnd/msgrcv //消息发送和接收
msgctl
信号量:sem.h semid_ds sem
int semget(key_t key,int nsems,int semflg)
semctl 信号量控制
semop() // P ,V ,Z(进程阻塞直到信号量为0)
共享内存:创建(shmget),映射(shmat),读写,释放(shmdt)
shmctl
五、网络通信
-I //include 目录
-L //静态库目录?动态也可以
-l //小写L,接静态库名称?动态也可以
-DXXX=‘“XXFF”’ //-D直接定义宏
-c 只编译
-O 优化
-g 生成调试信息
splint , gprof, cflow , dbx , gdb ,sdb //除了工具,还有日志记录调试更便捷
动态库:隐式调用 自动加载,与静态库一致 使用时,cc 后面加上路径,接口不变可以直接换so文件
显示调用 用dlopen
动态库创建:位置无关码(PIC)型.o
gcc -O -shared -shared -o xxx.so xxx.c
LD_LIBRARY_PATH //LINUX下设置这个环境目录,放动态库
#include <dlfcn.h> dlopen() / dlsym()
显示调用动态库流程
gcc -O -o tds tds.c -ldl //-ldl 固定写法 显示调用动态库时用
二、文件系统
超级块结构 filsys.h ; i node ino.h ;文件属性 stat.h ;
termio.h struct termio ioctl()
三、并发程序设计
sysproc //标识号0 调度系统中运行的进程, init // 标识号为1
geteuid() 进程有效用户ID,getegid() 进程有效组ID
fork-exec;vfork-exec模型
system() == vfork-exec
wait 实现父子进程之间同步:函数wait挂起调用它的进程,直到它的任一子进程退出
waitpid wait加强版 <sys/wait.h>
避免僵死进程 :fork两次让子进程退出,子子进程的父进程更改为进程init
四、进程通信
popen() pclose
mkfifo/mknod k1 p 有名管道用文件操作调用使用
消息对列是UNIX内核中一个先进先出链表结构
狭义讲IPC特指消息对列,信号量,共享内存
ipc /ipcrm <sys/msg.h> struct msqid_qs
int msgget(key_t key,int msgflg); //创建消息队列
msgsnd/msgrcv //消息发送和接收
msgctl
信号量:sem.h semid_ds sem
int semget(key_t key,int nsems,int semflg)
semctl 信号量控制
semop() // P ,V ,Z(进程阻塞直到信号量为0)
共享内存:创建(shmget),映射(shmat),读写,释放(shmdt)
shmctl
五、网络通信
相关文章推荐
- 《精通Unix下C语言与项目实践》读书笔记(16) 推荐
- 不要在Unix下遍桌面程序(2)《精通Unix下C语言与项目实践》读
- 精通JSF:基于EJB、Hibernate、Spring整合开发与项目实践 --我的第一本合著书终于出版了
- Unix朝代歌《精通Unix下C语言与项目实践》读书笔记(7) 推荐
- 不要在Unix下遍桌面程序(1)《精通Unix下C语言与项目实践》读
- Unix与Linux的关系《精通Unix下C语言与项目实践》读书笔记(6)
- Unix与Linux的关系《精通Unix下C语言与项目实践》读书笔记(6
- 第五周实践项目3————时间类(1)
- 《C语言及程序设计》实践项目——动态数组 ->【项目1-学生人数没个准】
- 数据结构上机实践第八周项目6- 猴子选大王(数组版)
- web项目 easyui-datagrid开发实践
- 第七周实践项目~排队模拟看病
- C++程序设计-第12周函数序设计上机实践项目
- 第九周 数据结构实践项目——数组和广义表【项目3.1-稀疏矩阵的三元组表示的实现及应用】
- 第三周上机实践项目——时间类
- 第十三周实践项目4————立体类族共有的抽象类
- 第十周实践项目之计算个人所得税
- 第9周实践项目3-稀疏矩阵的三元组表示的应用(3.2)
- MVC项目实践,在三层架构下实现SportsStore-11,使用Knockout实现增删改查
- 第五周上机实践项目1(1):三角形类雏形