转自:http://hi.baidu.com/%C1%F8826742781/blog/item/82d6b9ff6aad4138700eec7d.html#lastcmt
<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);进程向自身发送信号 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)删除信号量
|