<assert.h>         验证程序断言 
 <cpio.h >           cpio归档值 
 <ctype.h >           字符类型 
 <dirent.h >         目录项 
 <errno.h >           出错码 
 <fcntl.h >           文件控制 
 <float.h >           浮点常数 
 <signal.h >         信号 
 <stdarg.h >         可变参数表 
 <stddef.h >         标准定义 
 <stdio.h >           标准I/O库 
 <stdlib.h >         公用函数 
 <string.h >         字符串操作 
 <tar.h >             tar归档值 
 <termios.h >         终端I/O  
 <time.h >           时间和日期 
 <ulimit.h >         用户限制 
 <unistd.h >         符号常数 
 <utime.h >           文件时间 
 <sys/ipc.h >         IPC  
 <sys/msg.h >         消息队列 
 <sys/sem.h >         信号量 
 <sys/shm.h >         共享存储 
 <sys/stat.h >       文件状态 
 <sys/times.h >       进程时间 
 <sys/types.h >       原系统数据类型 
 <sys/wait.h >       进程控制 1、 Linux中一些头文件的作用:
 <assert.h>:ANSI C。提供断言,assert(表达式)
 <glib.h>:GCC。GTK,GNOME的基础库,提供很多有用的函数,如有数据结构操作函数。使用glib只需要包含<glib.h>
 <dirent.h>:GCC。文件夹操作函数。struct dirent,struct DIR,opendir(),closedir(),readdir(),readdir64()等<ctype.h>:ANSI C。字符测试函数。isdigit(),islower()等
 <errno.h>:ANSI C。查看错误代码errno是调试程序的一个重要方法。当linuc C api函数发生异常时,一般会将errno变量(需include errno.h)赋一个整数值,不同的值表示不同的含义,可以通过查看该值推测出错的原因。在实际编程中用这一招解决了不少原本看来莫名其妙的问题。比较麻烦的是每次都要去linux源代码里面查找错误代码的含义,现在把它贴出来,以后需要查时就来这里看了。来自linux 2.4.20-18的内核代码中的/usr/include/asm/errno.h
 <getopt.h>:处理命令行参数。getopt()2、
 -------------------------
 linux常用头文件如下:
 POSIX标准定义的头文件
 <dirent.h>        目录项
 <fcntl.h>         文件控制
 <fnmatch.h>    文件名匹配类型
 <glob.h>    路径名模式匹配类型
 <grp.h>        组文件
 <netdb.h>    网络数据库操作
 <pwd.h>        口令文件
 <regex.h>    正则表达式
 <tar.h>        TAR归档值
 <termios.h>    终端I/O
 <unistd.h>    符号常量
 <utime.h>    文件时间
 <wordexp.h>    字符扩展类型
 -------------------------
 <arpa/inet.h>    INTERNET定义
 <net/if.h>    套接字本地接口
 <netinet/in.h>    INTERNET地址族
 <netinet/tcp.h>    传输控制协议定义
 -------------------------
 <sys/mman.h>    内存管理声明
 <sys/select.h>    Select函数
 <sys/socket.h>    套接字借口
 <sys/stat.h>    文件状态
 <sys/times.h>    进程时间
 <sys/types.h>    基本系统数据类型
 <sys/un.h>    UNIX域套接字定义
 <sys/utsname.h>    系统名
 <sys/wait.h>    进程控制
 ------------------------------
 POSIX定义的XSI扩展头文件
 <cpio.h>    cpio归档值
 <dlfcn.h>    动态链接
 <fmtmsg.h>    消息显示结构
 <ftw.h>        文件树漫游
 <iconv.h>    代码集转换使用程序
 <langinfo.h>    语言信息常量
 <libgen.h>    模式匹配函数定义
 <monetary.h>    货币类型
 <ndbm.h>    数据库操作
 <nl_types.h>    消息类别
 <poll.h>    轮询函数
 <search.h>    搜索表
 <strings.h>    字符串操作
 <syslog.h>    系统出错日志记录
 <ucontext.h>    用户上下文
 <ulimit.h>    用户限制
 <utmpx.h>    用户帐户数据库
 -----------------------------
 <sys/ipc.h>    IPC(命名管道)
 <sys/msg.h>    消息队列
 <sys/resource.h>资源操作
 <sys/sem.h>    信号量
 <sys/shm.h>    共享存储
 <sys/statvfs.h>    文件系统信息
 <sys/time.h>    时间类型
 <sys/timeb.h>    附加的日期和时间定义
 <sys/uio.h>    矢量I/O操作
 ------------------------------
 POSIX定义的可选头文件
 <aio.h>        异步I/O
 <mqueue.h>    消息队列
 <pthread.h>    线程
 <sched.h>    执行调度
 <semaphore.h>    信号量
 <spawn.h>     实时spawn接口
 <stropts.h>    XSI STREAMS接口
 <trace.h>     事件跟踪 


 

1,系统调用文件的操作函数
#inlclude <fcntl.h>
int open(char *name,int how)第二个参数,O_RDONLY O_WRONLY O_RDWR O_CREAT
#include <unistd.h>
int close(int fd)
size_t read(int fd,void *buf, size_t count)
size_t write(int fd,const void *buf,size_t count)
sleep(1)系统睡眠一秒钟,最小单位为一秒。
#define msleep(x) usleep(x*1000)
msleep(500);系统睡眠0.5秒
 
#include <stdio.h>
perror("会出现错误的函数名")
#include <string.h>
char *strerror(int errnum)依据错误代码errnum来查找错误原因字符串
char *strcpy(char *dest,const char *src)
int strcmp(char *s1,const char *s2) s1若等于s2的值则返回0值
int strncmp(char *s1,const char *s2,int n)前n个字符串比较
 
2,进程控制函数
#include <unistd.h>
pid_t fork(void)子进程中返回0父进程中返回子进程ID出错返回-1
pid_t getpid(void)  pid_t getppid(void)
pid_t vfork(void)
exec函数族
进程pid的类型为pid_t类型,它包含于#include <sys/types.h>若定义一个进程pid变量,则需要包含此头文件
 
exit(n)结束进程父进程可以由wait函数来获得子进程结束装状态。
在进程结束的时候,会关闭文件描述符号,做一些清理工作,只保留进程返回状态等信息
调用exit(),子进程会关闭所有打开的进程描述符  exit会作清理工作,比如说,释放内存(在C++里面会主动的调用析构函数,),关闭文件句柄的工作,包括刷新IO流。
_exit(n)直接退出,不会做一些清理工作,也不会关闭文件描述符。
#include <sys/wait.h>
pid_t wait(int *status)等待任意子进程结束。子进程结束状态值由status返回。
如WEXITSTATUS(status)可以获得exit(2)中返回的值,status=2,这样就可以知道所等待的为哪个进程。如果不用这个宏转换,则status=512.
pid_t waitpid(pid_t pid,int status,int options)  可以指定等待某个进程号pid的进程结束
在使用waitpid函数时还用到了pid参数,所以还要加上#include <sys/types.h>
关于进程等待函数还有很多宏将status转换为需要的值,需要了解。
 
3,进程间通信-管道
#include <unistd.h>
int pipe(int filedes[2])
 
4,进程间通信-命名管道
#include <sys/types.h> #include <sys/stat.h>
int mkfifo(const char *pathname,mode_t mode)
对于命名管道的操作同普通文件的操作
 
5,消息队列
数据类型key_t是在头文件sys/types.h中定义的,它是一个长整形的数据。
key=ftok(".",'A')  #include <sys/types.h> #include <sys/ipc.h>
 
所属头文件:#include<sys/types.h> #include <sys/ipc.h> #include <sys/msg.h>
int msgid;
msgid=msgget(key, IPC_CREAT | IPC_EXCL | 0666);
struct msg
{
    long mtype;
    char mtext[50];
}msg1,msg2;  //消息队列缓冲区
int rcvtype=1;
msgsnd(msgid,&msg1,6,0)  6个字节,最后一个参数填写为0表示函数调用阻塞直到满足条件为止。
msgrcv(msgid,&msg2,6,rcvtype,0)   最后一个参数也可为IPC_NOWAIT,没有收到消息返回-1
msgctl(msgid,IPC_RMID,NULL);  删除消息队列
 
6,进程间通信-信号
#include <signal.h>
 
int kill(pid_t pid,int sig)
int raise(int signo);进程向自身发送信号
raise(signo)等价于kill(getpid(),signo);alarm(2)定时两秒后,产生SIGALRM信号,系统默认处理是结束进程。
 
int pause(void) //pause函数使调用进程挂起直至捕捉到一个信号。
signal(SIGINT,ctrl_c)  ctrl_c为函数名功能:发出信号后,调用信号处理函数
 
7,信号集函数组 阻塞信号
信号集数据结构的定义,sigset_t为结构体数据类型
sigset_t intmask;
sigemptyset(&intmask);
sigaddset(&intmask,SIGINT);
sigdelset(&intmask,SIGINT);
sigprocmask(int how,const sigset_t *set,sigset_t *oset)
sigpromask(SIGBLOCK,&intmask,NULL)
 
8,线程
#include <pthread.h>
线程ID类型为pthread_t为结构体类型
获得线程ID的办法pthread_t tid; tid=pthread_self();
 
pthread_create(&tid,NULL,thread,NULL)  第二个参数为线程属性,第三个参数为线程。第四个参数是可以向该线程传递参数。  线程void *thread(void *arg)
pthread_exit((void *)2)  //与return((void *)2)的区别?谁可以解答。。。
void *tret;
pthread_join(tid,&tret);
pthread_cancel(tid);
pthread_cleanup_push(fun,NULL);第一个参数为清理函数,第二个为传参,线程清理处理程序
pthread_cleanup_pop(0); 0表示线程结束时不执行清理函数,非0执行,两函数配对使用。
调用pthread_exit时,或响应取消时,即使是pthread_cleanup_pop(0);也执行清理函数。
 
互斥锁
互斥锁类型为pthread_mutex_t mutex1
pthread_mutex_init(&mutex1,NULL)互斥锁的创建,第二个参数为空,表示默认属性。
pthread_mutex_destory(&mutex1)清除一个互斥锁
pthread_mutex_lock(&mutex1)
pthread_mutex_unlock(&mutex1)
 
信号量
#include <semaphore.h>
信号量的类型sem_t sem1;
sem_init(&sem1,0,n)信号量的初始化,第二个参数Linux没能实现在进程间信号量的共享,所以值为0。
第三个参数为无符号整型,n表示信号量初始化的值
sem_wait(&sem1)  P操作
sem_post(&sem1)  V操作
用PV实现线程间的互斥与同步功能
int sem_getvalue(sem_t *sem)取得信号量的值
int sem_destroy(sem_t *sem)删除信号量