linux下创建和读取符号链接symlink、symlinkat和readlink、readlinkat函数使用心得。
代码:
#include<unistd.h>
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 <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <string.h>
#include <errno.h>
#include <sys/types.h>
#include <dirent.h>
#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