代码改变世界

精通UNIX下C语言编程与项目实践

2013-08-23 21:41  anjsoft  阅读(351)  评论(0编辑  收藏  举报

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

五、网络通信