iis服务器助手广告广告
返回顶部
首页 > 资讯 > 操作系统 >Linux中stat函数和stat命令使用详解
  • 903
分享到

Linux中stat函数和stat命令使用详解

Linuxstat函数Linuxstat命令 2022-06-03 14:06:46 903人浏览 泡泡鱼
摘要

stat函数和stat命令 linux文件里的【inode = index node】解释:要理解inode必须了解磁盘和【目录项】,inode实际是连接【目录项】和磁盘的中间物质。 图里的大圈代表硬件的磁盘,里面的

stat函数和stat命令

linux文件里的【inode = index node】解释:要理解inode必须了解磁盘和【目录项】,inode实际是连接【目录项】和磁盘的中间物质。

图里的大圈代表硬件的磁盘,里面的小圈代表某个文件存储在磁盘上了。

【inode = index node】的node(承载node信息的结构体是:stat,stat的定义在后面 )里面有:

  1. 文件大小
  2. 文件的最后修改时间
  3. 文件的所属用户
  4. 文件的权限
  5. 硬链接计数(ls -l 显示出来的数字)
  6. 块位置:指定文件存储在磁盘的具体位置。

下图中的hello是个普通文件,hello.hard是hello的硬链接

文件夹里放的就是每个文件的【目录项】如下图,【目录项】里有:

  1. 文件名
  2. 该目录项的大小
  3. 文件的类型
  4. inode

如何查看文件的【inode】呢?使用【-i】选项


ls -li 文件名

执行结果:

ys@ys-VirtualBox:~/lianxi1$ ls -li hello hello.hard
3801352 -rw-rw-r-- 2 ys ys 0 4月  24 11:01 hello
3801352 -rw-rw-r-- 2 ys ys 0 4月  24 11:01 hello.hard

发现hello和hello.hard的inode(3801352)是相同的,也就说明了,只在磁盘上存了一份。

如何查看目录项呢?用eMacs或者vim打开目录(lianxi1),截图如下。但是看不到文件的【inode】。

1,stat函数:取得指定文件的文件属性,文件属性存储在结构体stat里。


#include <sys/types.h>
#include <sys/stat.h>
#include <unistd.h>

int stat(const char *pathname, struct stat *statbuf);
int fstat(int fd, struct stat *statbuf);
int lstat(const char *pathname, struct stat *statbuf);

struct stat 结构体:


struct stat {
    dev_t  st_dev;   
    ino_t  st_ino;   
    mode_t st_mode;  
    nlink_t st_nlink;  
    uid_t  st_uid;   
    gid_t  st_gid;   
    dev_t  st_rdev;  
    off_t  st_size;  
    blksize_t st_blksize;  
    blkcnt_t st_blocks;  

    

    struct timespec st_atim; 
    struct timespec st_mtim; 
    struct timespec st_ctim; 

   #define st_atime st_atim.tv_sec  
   #define st_mtime st_mtim.tv_sec
   #define st_ctime st_ctim.tv_sec
   };

st_dev:设备ID,不太常用
st_ino:【inode】,【inode】是啥?不知道就看上面关于【inode】的解释
st_mode:文件的类型和权限,共16位,如下图。

  • 0-11位控制文件的权限
  • 12-15位控制文件的类型

0-2比特位:其他用户权限
3-5比特位:组用户权限
6-8比特位:本用户权限
9-11比特位:特殊权限
12-15比特位:文件类型(因为文件类型只有7中,所以用12-14位就够了

文件类型的宏如下(下面的数字是8进制):

  • S_IFSOCK 0140000 Socket
  • S_IFLNK 0120000 symbolic link(软连接)
  • S_IFREG 0100000 regular file(普通文件)
  • S_IFBLK 0060000 block device(块设备文件)
  • S_IFDIR 0040000 directory(目录)
  • S_IFCHR 0020000 character device(字符设备文件)
  • S_IFIFO 0010000 FIFO(管道)

判断文件类型的函数,返回true,false  
 S_ISREG(stat.st_mode) is it a regular file?
 S_ISDIR(stat.st_mode) directory?
 S_ISCHR(stat.st_mode) character device?
 S_ISBLK(stat.st_mode) block device?
 S_ISFIFO(m) FIFO (named pipe)?
 S_ISLNK(stat.st_mode) symbolic link? (Not in POSIX.1-1996.)
 S_ISSOCK(stat.st_mode) socket? (Not in POSIX.1-1996.)

文件权限的宏如下:


 S_ISUID  04000 set-user-ID bit
  S_ISGID  02000 set-group-ID bit (see below)
  S_ISVTX  01000 sticky bit (see below)

  S_IRWXU  00700 owner has read, write, and execute permission
  S_IRUSR  00400 owner has read permission
  S_IWUSR  00200 owner has write permission
  S_IXUSR  00100 owner has execute permission

  S_IRWXG  00070 group has read, write, and execute permission
  S_IRGRP  00040 group has read permission
  S_IWGRP  00020 group has write permission
  S_IXGRP  00010 group has execute permission

  S_IRWXO  00007 others (not in group) have read, write, and
       execute permission
  S_IROTH  00004 others have read permission
  S_IWOTH  00002 others have write permission
  S_IXOTH  00001 others have execute permission
  • st_nlink:硬连接计数
  • st_uid:这个文件所属用户的ID
  • st_gid:这个文件所属用户的组ID
  • st_rdev:特殊设备的ID,不太常用
  • st_size:文件的大小
  • st_blksize:不明是干啥的
  • st_blocks:不明是干啥的
  • struct timespec st_atim:最后访问的时间
  • struct timespec st_mtim:最后修改的时间
  • struct timespec st_ctim:最后状态改变的时间

struct timespec {
	__kernel_time_t	tv_sec;	 当前时间到1970.1.1 00:00:00的秒数
	long		tv_nsec;	/纳秒数(不知道从哪到哪的)
};
1s 秒  = 1000ms 毫秒
1ms 毫秒 = 1000us 微秒
1us 微秒 = 1000ns 纳秒

pathname:文件名

返回值:0代表成功;-1代表失败,并设置error

例子:statbuf是结构体stat,可以看出来st_mode是个10进制的数字。

st_mode

用gdb显示st_mode,发现返回的st_mode是个10进制的数字,用gdb的【p/o】(o代表用8进制表示)命令把10进制的33204转换成了8进制的【0100664】,第一个0代笔是8进制,后三位的【100】代表文件类型,从上面的说明可以看出来【100】代表普通文件,最后三位的【664】代表这个文件的权限(本用户:rw-,组用户:rw-,其他用户:r--)。所以从st_mode里就可以得知文件的类型和权限设置(只使用了16个比特位,真的好节省空间,牛逼!)

st_uid

st_gid

发现st_uid和st_gid是1000,但这个1000怎么和用户对应上呢,查看/etc/passwd文件,发现用于ys的uid和gid都是1000,所以就对应上了。

stat命令,是stat函数对应,执行结果如下:


ys@ys-VirtualBox:~/lianxi1$ stat hello
 File: hello
 Size: 11  	Blocks: 8   IO Block: 4096 regular file
Device: 801h/2049d	Inode: 3801352  Links: 2
Access: (0764/-rwxrw-r--) Uid: ( 1000/  ys) Gid: ( 1000/  ys)
Access: 2019-04-24 17:02:39.199461489 +0800
Modify: 2019-04-24 16:54:16.407461489 +0800
Change: 2019-04-24 17:03:44.927461489 +0800

2,getpwuid函数:返回/etc/passwd文件里指定uid的行,把这一行的信息放入结构体passwd中。虽然返回值是指针,但不需要调用free函数。


#include <sys/types.h>
#include <pwd.h>
struct passwd *getpwnam(const char *name);
struct passwd *getpwuid(uid_t uid);

struct passwd {
 char *pw_name;  
 char *pw_passwd;  
 uid_t pw_uid;  
 gid_t pw_gid;  
 char *pw_gecos;  
 char *pw_dir;  
 char *pw_shell;  
};

3,getgrgid函数:返回/etc/group文件里指定gid的行,把这一行的信息放入结构体group中。虽然返回值是指针,但不需要调用free函数。


#include <sys/types.h>
#include <grp.h>
struct group *getgrnam(const char *name);
struct group *getgrgid(gid_t gid);

struct group {
 char *gr_name;  
 char *gr_passwd;  
 gid_t gr_gid;   
 char **gr_mem;   
};

4,localtime函数:传入从stat函数里得到的st_mtim.tv_sec(当前时间到1970.1.1 00:00:00的秒数),得到结构体tm。虽然返回值是指针,但不需要调用free函数。


#include <time.h>
struct tm *localtime(const time_t *timep);
struct tm {
 int tm_sec; 
 int tm_min; 
 int tm_hour; 
 int tm_mday; 
 int tm_mon; 
 int tm_year; 
 int tm_wday; 
 int tm_yday; 
 int tm_isdst; 
};

5,lstat函数:stat碰到软链接,会追述到源文件,穿透;lstat并不会穿透。

例子:模仿ls -l 文件


#include <sys/types.h>
#include <sys/stat.h>
#include <unistd.h>
#include <stdio.h>
#include <string.h>
#include <pwd.h>//getpwuid
#include <stdlib.h>
#include <time.h>//localtime
#include <grp.h>//getgrgid

int main(int arGC, char* argv[]){

 struct stat sbuf;
 //stat(argv[1], &sbuf);
 lstat(argv[1], &sbuf);

 char str[11] = {0};
 memset(str, '-', (sizeof str - 1));
 
 //文件类型
 if(S_ISREG(sbuf.st_mode)) str[0] = '-';
 if(S_ISDIR(sbuf.st_mode)) str[0] = 'd';
 if(S_ISCHR(sbuf.st_mode)) str[0] = 'c';
 if(S_ISBLK(sbuf.st_mode)) str[0] = 'b';
 if(S_ISFIFO(sbuf.st_mode)) str[0] = 'p';
 if(S_ISLNK(sbuf.st_mode)) str[0] = 'l';
 if(S_ISSOCK(sbuf.st_mode)) str[0] = 's';

 //本用户的文件权限
 if(sbuf.st_mode & S_IRUSR) str[1] = 'r';
 if(sbuf.st_mode & S_IWUSR) str[2] = 'w';
 if(sbuf.st_mode & S_IXUSR) str[3] = 'x';
 
 //本用户的组的文件权限
 if(sbuf.st_mode & S_IRGRP) str[4] = 'r';
 if(sbuf.st_mode & S_IWGRP) str[5] = 'w';
 if(sbuf.st_mode & S_IXGRP) str[6] = 'x';
 
 //其他用户的文件权限
 if(sbuf.st_mode & S_IROTH) str[7] = 'r';
 if(sbuf.st_mode & S_IWOTH) str[8] = 'w';
 if(sbuf.st_mode & S_IXOTH) str[9] = 'x';

 char ymd[20] = {0};
 //取得日期和时间
 struct tm* tm = localtime(&sbuf.st_atim.tv_sec);
 sprintf(ymd, "%2d月 %2d %02d:%02d", tm->tm_mon + 1, tm->tm_mday,
	 tm->tm_hour + 1,tm->tm_sec);
 
 //-rw-r--r-- 1 ys ys 134 4月 25 09:21 st2.c
 printf("%s %ld %s %s %ld %s %s\n", str, sbuf.st_nlink,
	 getpwuid(sbuf.st_uid)->pw_name, getgrgid(sbuf.st_gid)->gr_name,
	 sbuf.st_size, ymd, argv[1]);
 return 0;
}

6,access函数:判断调用程序的用户对于指定文件的权限(可读?可写?可执行?)


#include <unistd.h>
int access(const char *pathname, int mode);

例子:


#include <stdio.h>
#include <unistd.h>//access

int main(int argc, char* argv[]){
 if(access(argv[1], R_OK) == 0)
 printf("read ok\n");
 if(access(argv[1], W_OK) == 0)
 printf("write ok\n");
 if(access(argv[1], X_OK) == 0)
 printf("exe ok\n");
 if(access(argv[1], F_OK) == 0)
 printf("exists\n");
}

先用ls -l 查看/usr/include/time.h文件的权限,结果如下


ys@ys-VirtualBox:~/lianxi$ ls -l /usr/include/time.h
-rw-r--r-- 1 root root 10360 4月 17 2018 /usr/include/time.h

用ys用户执行例子程序,查看/usr/include/time.h文件,结果如下。因为time.h是属于root用户的,对于其他用户来说是[r--],所以得出下面的结果。


ys@ys-VirtualBox:~/lianxi$ ./ac /usr/include/time.h
read ok
exists

还是用ys用户执行,但是加上sudo,结果如下。发现结果和root用户相同。因为加了sudo,就编程了root用户。


ys@ys-VirtualBox:~/lianxi$ sudo ./ac /usr/include/time.h
[sudo] passWord for ys: 
read ok
write ok
exists

7,truncate函数:截断文件和扩展文件的大小


#include <unistd.h>
#include <sys/types.h>
int truncate(const char *path, off_t length);

path:文件
length:
length大于原来文件的大小,则扩展文件的大小至length
length小于原来文件的大小,则截断文件的大小至length

8,link函数:创建硬链接


#include <unistd.h>
int link(const char *oldpath, const char *newpath);

返回值:成功返回0,失败返回-1,并设置errno。

9,symlink函数:创建软链接


#include <unistd.h>
int symlink(const char *target, const char *linkpath);

返回值:成功返回0,失败返回-1,并设置errno。

10,readlink函数:找到软链接对应的实际文件,把文件的名字放入buf里。注意:硬链接不行。


#include <unistd.h>
ssize_t readlink(const char *pathname, char *buf, size_t bufsiz);

返回值:成功返回写入buf的字节数,失败返回-1,并设置errno。

11,unlink函数:删除软硬链接,也可以删除文件。


#include <unistd.h>
int unlink(const char *pathname);

返回值:成功返回0,失败返回-1,并设置errno。

有个特殊用法:下面的open代码想要创建hello文件,然后直接用unlink删除,但是能写入成功,ret是大于0的,程序执行完,发现没有做成hello文件。

结论:当执行unlink后,计数为0后,但,发现别的进程还引用这个文件,这个时间点,unlink不会删除这个文件,等这个进程结束后,再删除,所以下面的write代码能够写入成功。
利用这个特点可以实现:在线观看视频时,实际是把视频文件下载到了本地(然后代码里,使用unlink),看完后视频文件的计数为0,就自动删除了,不怕视频被泄露出去。


#include <unistd.h>
#include <sys/types.h>
#include <stdio.h>
#include <sys/stat.h>
#include <fcntl.h>

int main(){
 int fd = open("hello", O_WRONLY | O_CREAT, 0666);
 unlink("hello");
 int ret = write(fd, "aaa", 4);
 if(ret > 0){
 printf("write OK\n");
 }
 
}

12,chown函数:改变文件的所属用户和组


#include <unistd.h>
int chown(const char *pathname, uid_t owner, gid_t group);

pathname:文件

owner:用户ID(数字的)/etc/passwd

group:组ID(数字的)/etc/group

返回值:0成功,-1失败。

13,rename函数:重命名


#include <stdio.h>
int rename(const char *oldpath, const char *newpath);

oldpath :原来的文件名后者目录

newpath:新的文件名后者目录

返回值:0成功,-1失败。

14,getcwd函数:获得当前工作的目录


#include <unistd.h>
char *getcwd(char *buf, size_t size);

buf:当前工作的目录

size:缓冲区大小

返回值:成功返回当前工作的目录 失败返回NULL

15,chdir函数:改变进程的工作目录


#include <unistd.h>
int chdir(const char *path);

path:目标工作目录

返回值:0成功,-1失败

16,mkdir函数:创建目录


#include <sys/stat.h>
#include <sys/types.h>
int mkdir(const char *pathname, mode_t mode);

pathname:目标工作目录mode:mode & ~umask & 0777 。注意,如果没有x权限,则无法cd进入这个目录。返回值:0成功,-1失败

17,rmdir函数:删除目录,目录必须是空目录,也就是里面没有任何文件。


#include <unistd.h>
int rmdir(const char *pathname);

18,opendir函数:打开目录


#include <sys/types.h>
#include <dirent.h>
DIR *opendir(const char *name);

name:目录名

返回值:a pointer to the directory stream

19,readdir函数:读目录


#include <sys/types.h>
#include <dirent.h>
DIR *opendir(const char *name);

dirp:opendir函数的返回值

返回值:结构体dirent,可以理解成最上面说的【目录项】NULL代表读到末尾或者有错误  NULL以外代表目录项的内容

20,closedir函数:关闭目录


#include <sys/types.h>
#include <dirent.h>
int closedir(DIR *dirp);

dirp:opendir函数的返回值

21,strerron函数:打印出errno对应的文字信息。


#include <string.h>
char *strerror(int errnum);

errnum的宏放在文件:/usr/include/asm-generic/errno.h

例子:


#include <string.h>
#include <stdio.h>
#include <asm-generic/errno.h>//EDEADLK
int main(){
 char* buf = strerror(EDEADLK);
 printf("%s\n", buf);//Resource deadlock avoided
}

22,dup和dup2函数:文件描述符的重定向


#include <unistd.h>
int dup(int oldfd);
int dup2(int oldfd, int newfd);

dup:和open类似,先打开一个新的文件描述符,让新的文件描述符也指向:oldfd指向的地方。成功返回新打开的文件描述符;失败返回-1.

dup2:先消除newfd的指向再让newfd指向oldfd指向的地方成功返回newfd;失败返回-1.

例子:调用printf2次,第一次printf把内容写到文件;第二次printf把内容打印到屏幕。


#include <stdio.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>

int main(){

 int oldfd = dup(STDOUT_FILENO);
 int fd = open("www", O_WRONLY | O_CREAT, 0666);
 dup2(fd, STDOUT_FILENO);
 printf("aaaa\n");
 fflush(stdout);
 int ret = dup2(oldfd, STDOUT_FILENO);
 //int ret = dup2(oldfd, 6);
 //perror("dup2:");
 printf("reg:%d\n", ret);
 printf("aaaa\n");
 close(fd);
}

到此这篇关于Linux中stat函数和stat命令使用详解的文章就介绍到这了,更多相关Linux stat函数和stat命令内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Linux中stat函数和stat命令使用详解

本文链接: https://www.lsjlt.com/news/11513.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Linux中stat函数和stat命令使用详解
    stat函数和stat命令 linux文件里的【inode = index node】解释:要理解inode必须了解磁盘和【目录项】,inode实际是连接【目录项】和磁盘的中间物质。 图里的大圈代表硬件的磁盘,里面的...
    99+
    2022-06-03
    Linux stat函数 Linux stat命令
  • Linux中stat函数和stat命令怎么用
    小编给大家分享一下Linux中stat函数和stat命令怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Linux文件里的【inode = index nod...
    99+
    2023-06-28
  • stat函数与stat命令怎么在Linux系统中使用
    这篇文章将为大家详细讲解有关stat函数与stat命令怎么在Linux系统中使用,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。stat函数和stat命令linux文件里的【inode = i...
    99+
    2023-06-07
  • Linux stat命令的使用
    1.命令简介 stat命令用于显示文件或文件系统的详细信息。在显示文件信息时,比ls命令更加详细。 2.命令格式 stat [OPTION]... FILE.. 3.命令选项 -L, --dereferen...
    99+
    2022-06-03
    Linux 命令 Linux stat命令
  • Linux中如何使用stat命令
    小编给大家分享一下Linux中如何使用stat命令,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Linux常用命令stat 命令用于显示 inode 内容,sta...
    99+
    2023-06-28
  • Linux中stat命令怎么用
    这篇文章将为大家详细讲解有关Linux中stat命令怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Linux stat命令我们可以将stat命令看作是ls -l命令的更好版本。虽然-l标志提供了有关...
    99+
    2023-06-15
  • 怎么在Linux中使用stat命令
    这篇文章给大家介绍怎么在Linux中使用stat命令,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。ls 命令可能是每一个 Unix 使用者第一个学习的命令之一, 但它仅仅显示了 stat 命令能给出的信息的一小部分。s...
    99+
    2023-06-12
  • Linux中stat命令有什么用
    小编给大家分享一下Linux中stat命令有什么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Linux常用命令stat命令 用于显示文件的状态信息。stat命...
    99+
    2023-06-28
  • Linux系统中stat命令怎么用
    这篇文章给大家分享的是有关Linux系统中stat命令怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。在Linux系统中stat命令主要用于显示文件或文件系统的详细信息。语法 stat [...
    99+
    2023-06-28
  • Linux中stat命令显示文件的使用教程
    这篇文章主要讲解了“Linux中stat命令显示文件的使用教程”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Linux中stat命令显示文件的使用教程”吧!用法:stat [选项]... 文...
    99+
    2023-06-12
  • Linux中rz命令和sz命令使用详解大全
    sz命令 用途说明:sz命令是利用ZModem协议来从Linux服务器传送文件到本地,一次可以传送一个或多个文件。相对应的从本地上传文件到Linux服务器,可以使用rz命令。 常用参数 -a 以文本方式传...
    99+
    2022-06-04
    命令 详解 大全
  • linux中使用grep命令详解
    linux grep命令 Linux grep命令用于查找文件里符合条件的字符串;也可以用于查找内容包含指定的范本样式的文件。它能使用正则表达式搜索,用于在文件中搜索指定的字符串模式,列出含有匹配模式子符串的文件名,并输...
    99+
    2022-06-04
    linux grep
  • Linux rpm 命令参数使用详解
    rpm 执行安装包 二进制包(Binary)以及源代码包(Source)两种。二进制包可以直接安装在计算机中,而源代码包将会由RPM自动编译、安装。源代码包经常以src.rpm作为后缀名。 常用命令组合: ...
    99+
    2022-06-04
    详解 命令 参数
  • linux nslookup命令使用详解
    【nslookup何许人?】 nslookup命令,是linux里非常常用的网络命令,简而言之就是“查DNS信息用的”。 通过man nslookup可以看到对于nslookup的官方解释是“query Internet...
    99+
    2022-06-04
    linux nslookup命令 linux nslookup
  • Linux tee命令使用详解
    tee命令主要被用来向standout(标准输出流,通常是命令执行窗口)输出的同时也将内容输出到文件,下面是tee的man 信息 read from standard input and write to standa...
    99+
    2022-06-04
    Linux tee命令 Linux tee命令
  • Linux traceroute命令使用详解
    traceroute我们可以知道信息从你的计算机到互联网另一端的主机是走的什么路径。当然每次数据包由某一同样的出发点(source)到达某一同样的目的地(destination)走的路径可能会不一样,但基本上来说大部分时...
    99+
    2022-06-04
    Linux traceroute命令 Linux traceroute
  • Linux lsof命令使用详解
    lsof(list open files)是一个查看进程打开的文件的工具。 在 linux 系统中,一切皆文件。通过文件不仅仅可以访问常规数据,还可以访问网络连接和硬件。所以 lsof 命令不仅可以查看进程打开的文件、目...
    99+
    2022-06-04
    Linux lsof命令 Linux lsof
  • linux mpstat命令使用详解
    1. mpstat命令 1.1 命令格式 mpstat [ -A ] [ -u ] [ -V ] [ -I { SUM | CPU | SCPU | ALL } ] [ -P { cpu [,...] | ON ...
    99+
    2022-06-04
    linux mpstat命令
  • Linux中的screen命令使用详解
    GUN Screen: 官方网址:http://www.gnu.org/software/screen/ 1、简介 Screen是一款由GNU计划开发的用于命令行终端切换的自由软件。用户可以通过该软件同时连接多个本地...
    99+
    2022-06-04
    Linux screen命令 Linux screen
  • linux的ln命令使用参数详解
    本篇内容主要讲解“linux的ln命令使用参数详解”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“linux的ln命令使用参数详解”吧!这是linux中一个非常重要命令,请大家一定要熟悉。它的功能...
    99+
    2023-06-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作