linux下创建和读取符号链接symlink、symlinkat和readlink、readlinkat函数使用心得

#include
int symlink(const char*actualpath,const char *sympath);
 int symlinkat(const char *actualpath,int fd,const char *sympath);
                           两个函数返回值:若成功,返回0;若出错,返回-1
ssize_t readlink(const char* restrict pathname,char *restrict buf,size_t bufsize);
ssize_t readlinkat(int fd,const char* restrict pathname,char *restrict buf,size_t bufsize);
                           两个函数返回值:若成功,返回读取的字节数;若出错,返回-1


 
  

symlink函数创建了一个指向actualpath的新目录项sympath。在创建此符号链接时,并不要求actualpath已经存在。并且actualpath和sympath并不需要位于同一文件系统中。

symlinkat函数与symlink函数类似,但sympath参数根据相对于打开文件描述符引用的目录(由fd指定)进行计算。如果sympath参数指定的是绝对路径或者fd参数设置了AT_FDCWD值,那么symlinkat就等同于symlink函数。

readlink和readlinkat函数组合了open、read和close的所有操作。如果函数成功执行,则返回读入buf的字节数。在buf中返回的符号链接的内容不以null字符终止。

当pathname参数指定的是绝对路径名或者fd参数的值为AT_FDCWD,readlinkat函数的行为与readlink相同。但是,如果fd参数是一个打开目录的有效文件描述符并且pathname参数是相对路径名,则readlinkat计算相对于由fd代表的打开目录的路径。

symlinkat和readlinkat函数的实例程序如下:

#include 
#include 
#include 
#include 
#include 
#include 
#include 
#define BUFFSIZE 1024

int main(int argc,char *argv[])
{
    if(argc != 4){
        printf("param too few\n");
        exit(EXIT_FAILURE);
    }

    char buf[BUFFSIZE];
    ssize_t sz;
    DIR *dp;
    int fd;

    //获取相对路径名返回的文件描述符fd
    if((dp = opendir(argv[2])) == NULL){
        perror("opendir");
        exit(EXIT_FAILURE);
    }
    if((fd = dirfd(dp)) < 0){
        perror("dirfd");
        exit(EXIT_FAILURE);
    }

    //创建符号链接
    if(symlinkat(argv[1],fd,argv[3]) < 0){
        perror("symlinkat");
        exit(EXIT_FAILURE);
    }

    //读取符号链接
    memset(buf,0,sizeof(buf));
    if((sz = readlinkat(fd,argv[3],buf,sizeof(buf))) < 0){
        perror("readlinkat");
        exit(EXIT_FAILURE);
    }

    printf("buf:%s,length:%u\n",buf,(unsigned int)sz);
    close(fd);
    return 0;
}
测试结果:

当前目录下命令行输入:./a.out ./testsymlinkat.c ./foo ./mysymlink

输出:buf:./testsymlinkat.c,length:17

进入当前目录下的foo目录就能看到刚创建的符号链接mysymlink

你可能感兴趣的:(UNIX环境高级编程第三版)