Linux一些重要的头文件

来源:互联网 发布:印度 种姓 知乎 编辑:程序博客网 时间:2024/05/19 06:51

1.系统调用 ---文件的操作函数

#inlclude <fcntl.h>

int  open(char *name,int how)   文件打开

#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)   系统睡眠一秒钟,最小单位为一秒。

#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>

intmsgid;

msgid=msgget(key,IPC_CREAT | IPC_EXCL | 0666);

structmsg

{

    long mtype;

    char mtext[50];

}msg1,msg2;  //消息队列缓冲区

intrcvtype=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(inthow,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实现线程间的互斥与同步功能

intsem_getvalue(sem_t *sem) 取得信号量的值

intsem_destroy(sem_t *sem) 删除信号量

原创粉丝点击