当前位置: 首页 > article >正文

【Linux系统编程】基本IO函数

目录

    • 1、open 函数
    • 2、create 函数
    • 3、write 函数
    • 4、read 函数
    • 5、lseek 函数
    • 6、access 函数
    • 7、unlink 函数
    • 8、remove 函数
    • 9、fcntl 函数
      • 写锁互斥锁示例
      • 读锁共享锁示例

1、open 函数

头文件

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

函数定义

 int open(const char *pathname, int flags);  //一般用在已经才能在的文件int open(const char *pathname, int flags, mode_t mode); //用在新创建,并且自己显式设置权限

参数说明

pathname
要打开的文件路径(可以是绝对路径或相对路径)。

flags
文件打开模式,用于指定打开文件的方式。以下是常用的标志:

必选标志(必须指定其中一个):

O_RDONLY:只读模式。 O_WRONLY:只写模式。 O_RDWR:读写模式。

可选标志(可以组合使用):

O_CREAT:如果文件不存在,则创建文件。
O_EXCL:与O_CREAT一起使用,如果文件已存在,则返回错误。
O_TRUNC:如果文件存在且为普通文件,则将其长度截断为 0。
O_APPEND:以追加模式打开文件,每次写操作都会将数据追加到文件末尾。
O_NONBLOCK:以非阻塞模式打开文件。
O_SYNC:每次写操作都会等待数据写入磁盘。

mode
当使用 O_CREAT 标志时,需要指定文件的权限模式(八进制表示)。例如:
0644:文件所有者可读写,其他用户只读。
0755:文件所有者可读、写、执行,其他用户可读、执行。

0664 的每一位含义如下:

第一位 0:忽略(通常用于特殊权限,如 SUID、SGID 等)。
第二位 6:文件所有者具有读 ® 和写 (w) 权限。
第三位 6:文件所属组具有读 ® 和写 (w) 权限。
第四位 4:其他用户具有读 ® 权限

通过umask命令查看系统权限掩码
在这里插入图片描述
mode的实际权限是减去权限掩码后的权限,比如创建时mode=0666,权限掩码是0002,那么实际的权限是0664。如果mode=0775,实际还是0775,因为umask的0002是去除w权限,而mode中的5是r-x不包含w权限,所以就不减去2,还是0775。

返回值

成功时,返回一个文件描述符(非负整数)。一般成功是3(因为0,1,2被stdinstdoutstderr占用了)

失败时,返回 -1,并设置 errno 以指示错误类型。

注意:
open()可以打开设备文件,但是不能创建设备文件

示例:
创建并打开一个新文件(读写模式)

#include<stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>int main()
{const char *path = "hello.txt";int fd = open(path,O_WRONLY | O_CREAT | O_TRUNC,0664);if (fd < 0){perror("open file error");return -1;}printf("fd = %d\n",fd);close(fd);
}

2、create 函数

头文件

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

函数定义

int creat(const char *pathname, mode_t mode);

参数说明、返回值
同上

文件权限

文件的实际权限由 mode 参数和当前进程的 umask 共同决定。
计算公式:实际权限 = mode & ~umask。
例如: 如果 mode 为 0666,umask 为 0022,则实际文件权限为 0644

注意事项

  • creat() 函数只能以只写模式(O_WRONLY)打开文件。如果需要以读写模式打开文件,应使用 open() 函数。
  • 如果文件已存在,creat() 会清空文件内容。如果需要保留文件内容,应使用 open() 函数,并避免使用 O_TRUNC 标志。
  • creat() 函数在现代编程中较少使用,通常直接使用 open() 函数替代。

与 open() 的关系

creat() 函数是 open() 函数的一个特例,以下两种调用是等价的:

int fd1 = creat("file.txt", 0644);
int fd2 = open("file.txt", O_WRONLY | O_CREAT | O_TRUNC, 0644);

示例

#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>int main()
{int fd = creat("hello2.txt", 0664);if (fd < 0){perror("oppen file error");return -1;}close(fd);
}

3、write 函数

头文件

#include <unistd.h>

函数定义

ssize_t write(int fd, const void *buf, size_t count);

参数说明

fd:文件描述符,表示要写入的目标(例如文件、管道、套接字等)。
buf:指向要写入数据的缓冲区的指针。
count:要写入的字节数。

返回值

  • 成功时,返回实际写入的字节数(ssize_t 类型)。
  • 失败时,返回 -1,并设置 errno 以指示错误类型。

示例

#include<stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <string.h>typedef struct student
{char name[16];int age;
}stu_t;int main()
{const char *path = "hello2.txt";int fd = open(path,O_WRONLY | O_CREAT | O_TRUNC,0664);if (fd < 0){perror("oppen file error");return -1;}printf("fd = %d\n",fd);
#if 1//操作char *str = "hello world\n";char buf[128] = "hello world";int len1 = write(fd,str,strlen(str));if(len1 < 0){perror("write error");close(fd);return -1;}int len2 = write(fd,str,sizeof(str));if(len2 < 0){perror("write error");close(fd);return -1;}printf("len1 = %d\n",len1);printf("len2 = %d\n",len2);
#endif#if 1stu_t stu = {"zhangsan",18};int len = write(fd,&stu,sizeof(stu_t));  if(len < 0){perror("write data error");close(fd);return -1;}printf("len = %d\n",len);   //20
#endifclose(fd);
}

4、read 函数

头文件

#include <unistd.h>

函数定义

ssize_t read(int fd, void *buf, size_t count);

参数说明

  • fd:文件描述符,表示要读取的目标(例如文件、管道、套接字等)。
  • buf:指向存储读取数据的缓冲区的指针。
  • count:要读取的最大字节数。

返回值

  • 成功时,返回实际读取的字节数(ssize_t 类型)。
  • 返回 0 表示已到达文件末尾(EOF)。 //可以判断是否为空文件
  • 失败时,返回 -1,并设置 errno 以指示错误类型。

示例

#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <string.h>typedef struct student
{char name[16];int age;
} stu_t;int main()
{const char *path = "hello2.txt";int fd = open(path, O_RDONLY);if (fd < 0){perror("oppen file error");return -1;}printf("fd = %d\n", fd);#if 0       //循环读取char buf[5] = "";while (1){memset(buf,0,sizeof(buf));   //主要用于判断最后一次读的内容int len = read(fd, buf, sizeof(buf) - 1); // 尾0留一个字节if (len < 0){perror("read file error");close(fd);return -1;}if (len == 0) // len == 0 ,表示读到文件末尾break;printf("len = %d\n", len);printf("buf = %s\n", buf);}
#endif#if 1stu_t stu = {0};   //读取结构体内容int len = read(fd,&stu,sizeof(stu_t));if(len < 0){perror("read file error");close(fd);return -1;}printf("len = %d stu.name = %s stu.age = %d\n",len,stu.name,stu.age);
#endifclose(fd);
}

5、lseek 函数

头文件

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

函数定义

 off_t lseek(int fd, off_t offset, int whence);

参数说明

  • fd:文件描述符,表示要操作的文件。
  • offset:偏移量,表示要移动的字节数。 正数向右,负数向左
  • whence:基准位置,决定如何解释 offset 的值。它可以是以下常量之一:
    • SEEK_SET:从文件开头开始计算偏移量。
    • SEEK_CUR:从当前文件指针位置开始计算偏移量。
    • SEEK_END:从文件末尾开始计算偏移量。

返回值

  • 成功时,返回新的文件指针位置(从文件开头计算的字节数)。
  • 失败时,返回 -1,并设置 errno 表示错误原因。

注意事项

  • 对于普通文件,lseek() 允许将文件偏移量设置为超出文件末尾的位置。在这种情况下,后续的 write() 操作会扩展文件大小。
  • 对于管道、FIFO 或套接字,lseek() 不可用,因为这些设备不支持随机访问。
  • lseek() 不会导致 I/O 操作,它只是修改文件偏移量。

特殊用法

  • 获取文件大小:将文件偏移量移动到文件末尾,并返回当前偏移量。
off_t file_size = lseek(fd, 0, SEEK_END);
  • 扩展文件大小:将文件偏移量移动到超出文件末尾的位置,并写入数据。也叫空洞文件
    • 空洞文件的特性是:
      文件中存在未写入数据的区域(空洞)。
      这些空洞不会占用实际的磁盘空间。
      文件系统会记录文件的逻辑大小,但实际占用的磁盘空间只包括已写入数据的部分。
lseek(fd, 100, SEEK_END);
write(fd, "", 1);  // 扩展文件大小

示例

#include<stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <string.h>int main()
{const char *path = "hello2.txt";int fd = open(path,O_RDWR,0664);if (fd < 0){perror("oppen file error");return -1;}printf("fd = %d\n",fd);#if 1// lseek(fd,1,SEEK_SET);lseek(fd,-2,SEEK_END);char buf[128] = "";read(fd,buf,sizeof(buf) -1);printf("buf = %s\n",buf);//获取文件大小int size = lseek(fd,0,SEEK_END);    //先移动到末尾,再获取当前的位置printf("%d\n",size);//创建空洞文件int size2 = lseek(fd,50,SEEK_SET);write(fd,"a",1);printf("%d\n",size2);#endif#if 0char *str = "aaaaaaaa";write(fd,str,strlen(str));lseek(fd,0,SEEK_SET);char buf[128] = "";read(fd,buf,sizeof(buf)-1);printf("buf = %s\n",buf);close(fd);
#endif
}

6、access 函数

头文件

#include <unistd.h>

函数定义

int access(const char *pathname, int mode);

参数说明

  • pathname:文件或目录的路径。
  • mode:检查的权限模式,可以是以下值的组合:
    • F_OK:检查文件是否存在。
    • R_OK:检查是否具有读权限。,而不是实际用户 ID 和实际组 ID。
    • X_OK: 检查是否有可执行权限
    • W_Ok: 检查是否有可写权限
  • 如果文件权限发生变化,access() 的结果可能会失效,因为它只是检查当前状态。
  • 如果文件是符号链接,access() 会检查符号链接指向的目标文件的权限。

返回值

  • 成功:返回 0,表示文件存在且具有指定的访问权限。
  • 失败:返回 -1,并设置 errno 为以下值之一:
    • EACCES:访问被拒绝。
    • ENOENT:文件或路径不存在。
    • ENOTDIR:路径中的某个部分不是目录。
    • EROFS:文件系统只读,无法写入。

注意事项

  • access 函数检查的是 当前进程 的权限,而不是文件的权限位。

  • 如果文件是符号链接,access 会检查链接指向的目标文件的权限。

  • 在多线程程序中,使用 access 可能会导致竞争条件(race condition),因为文件的状态可能在检查和使用之间发生变化。

示例

#include<stdio.h>
#include <unistd.h>
#include <fcntl.h>
#include <sys/types.h>
#include <sys/stat.h>int main()
{// F_OK: check file exist or notif(access("hello.txt",F_OK) == 0){printf("hello.txt exist\n");}elseprintf("hello.txt not exist\n");//检查文件是否有读、写、执行权限if(access("hello.txt",W_OK | R_OK) == 0){printf("hello.txt have R_OK, W_OK\n");}elseprintf("hello.txt not have R_OK, W_OK\n");}

7、unlink 函数

头文件

#include <unistd.h>

函数定义

 int unlink(const char *pathname);

参数说明

  • pathname:要删除的文件的路径。

返回值

  • 成功时返回 0。
  • 失败时返回 -1

示例

#include <stdio.h>
#include <unistd.h>int main()
{//删除文件文件之前,判断文件是否存在if(access("hello2.txt",F_OK) == 0){int res = unlink("hello2.txt");if (res < 0){perror("unlink file error");return -1;}}}

8、remove 函数

头文件

#include <stdio.h>

函数定义

int remove(const char *pathname);

参数说明

  • pathname:要删除的文件的路径。

返回值

  • 成功时返回 0。
  • 失败时返回 -1

示例

#include <stdio.h>
#include <unistd.h>int main()
{  //remove 删除空目录if(access("dir",F_OK) == 0){int res = remove("dir");if (res < 0){perror("unlink file error");return -1;}}
}

9、fcntl 函数

头文件

 	   #include <unistd.h>#include <fcntl.h>

函数定义

int fcntl(int fd, int cmd, ... /* arg */ );

参数说明

  • fd:文件描述符,表示要操作的文件。
  • cmd:操作命令,指定要对文件描述符执行的操作。
  • arg:可选参数,具体内容取决于 cmd。

返回值

  • 成功时,返回值取决于 cmd。
  • 失败时,返回 -1。

常用命令(cmd)

- F_GETFL:获取文件状态标志(如 O_RDONLY、O_WRONLY、O_NONBLOCK 等)。

int flags = fcntl(fd, F_GETFL);

- F_SETFL:设置文件状态标志。

fcntl(fd, F_SETFL, flags | O_NONBLOCK); // 设置非阻塞模式

示例

#include <stdio.h>
#include <unistd.h>
#include <fcntl.h>
#include <stdlib.h>
#include <string.h>int main()
{int fd = STDIN_FILENO;int flags = fcntl(fd,F_GETFL);//获取原来的flagsflags = flags | O_NONBLOCK; //O_NONBLOCK:非阻塞fcntl(fd,F_SETFL,flags);//把新的flags设置进去char buf[128] = "";// int len = 0;// while(1)// {// 	len = read(fd,buf,sizeof(buf) - 1);// 	printf("len = %d\n",len);// 	if(len > 0)// 	{// 		printf("len = %d  buf = %s\n",len,buf);// 		break;// 	}// 	sleep(1);// }// 重新改为阻塞flags = flags^O_NONBLOCK;//异或:相同为0  不同为1fcntl(fd,F_SETFL,flags);//重新设置新的falgsmemset(buf,0,sizeof(buf));read(fd,buf,sizeof(buf));printf("buf = %s\n",buf);}

文件锁结构体 struct flock

struct flock {short l_type;   // 锁类型:F_RDLCK(读锁)、F_WRLCK(写锁)、F_UNLCK(解锁)short l_whence; // 起始偏移的基准:SEEK_SET、SEEK_CUR、SEEK_ENDoff_t l_start;  // 起始偏移off_t l_len;    // 锁定长度pid_t l_pid;    // 持有锁的进程 ID(F_GETLK 时有效)
};

示例

#include <stdio.h>
#include <unistd.h>
#include <fcntl.h>
#include <sys/types.h>
#include <sys/stat.h>int main()
{const char *path = "hello.txt";int fd = open(path,O_RDWR);if(fd < 0){perror("open file error");return -1;}struct flock rlock = {0};rlock.l_type = F_RDLCK;//读锁rlock.l_whence = SEEK_SET;  //文件开头rlock.l_start = 0;rlock.l_len = 0;  // 0表示锁整个文件rlock.l_pid = getpid(); //获取当前进程的进程号int res = fcntl(fd,F_SETLK,&rlock); //设置锁if(res < 0){perror("fcntl rlock error");close(fd);return -1;}struct flock lockstat = {0};fcntl(fd,F_GETLK,&lockstat);if(lockstat.l_type == F_RDLCK)printf("set read lock\n");else if(lockstat.l_type == F_WRLCK)printf("set write lock\n");else if(lockstat.l_type == F_UNLCK)printf("no lock\n");}

注意

  • 文件锁的作用范围:文件锁是基于进程的,不同进程之间的文件锁会相互影响。
  • 锁的类型:
    • 读锁(F_RDLCK):共享锁,允许多个进程同时获取读锁。
    • 写锁(F_WRLCK):互斥锁,只允许一个进程获取写锁。
  • 锁的继承:文件锁不会被子进程继承。

示例

写锁互斥锁示例

两个终端运行
读锁

#include <stdio.h>
#include <unistd.h>
#include <fcntl.h>
#include <sys/types.h>
#include <sys/stat.h>//return value加锁成功返回0,失败返回-1
int setlock(int fd,short locktype)
{struct flock lock = {0};lock.l_type = locktype;  //读锁lock.l_whence = SEEK_SET;  //文件开头lock.l_start = 0;lock.l_len = 0;  // 0表示锁整个文件lock.l_pid = getpid(); //获取当前进程的进程号int res = fcntl(fd,F_SETLK,&lock); //设置锁// int res = fcntl(fd,F_SETLKW,&lock); //阻塞加锁if(res < 0){return -1;}return 0;
}int main()
{const char *path = "hello.txt";int fd = open(path,O_RDWR);if(fd < 0){perror("open file error");return -1;}//加锁// if (setlock(fd,F_RDLCK)<0)// {//     perror("set lock error");//     close(fd);//     return -1;// }while (setlock(fd,F_RDLCK)<0){perror("set lock error");sleep(1);}//读char buf[128] = "";read(fd,buf,sizeof(buf) - 1);printf("buf = %s\n",buf);getchar();//解锁if(setlock(fd,F_UNLCK) < 0){perror("unlock error");close(fd);return -1;}close(fd);}

写锁

#include <stdio.h>
#include <unistd.h>
#include <fcntl.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <string.h>//return value加锁成功返回0,失败返回-1
int setlock(int fd,short locktype)
{struct flock lock = {0};lock.l_type = locktype;  //读锁lock.l_whence = SEEK_SET;  //文件开头lock.l_start = 0;lock.l_len = 0;  // 0表示锁整个文件lock.l_pid = getpid(); //获取当前进程的进程号int res = fcntl(fd,F_SETLK,&lock); //设置锁// int res = fcntl(fd,F_SETLKW,&lock); //阻塞加锁if(res < 0){return -1;}return 0;
}int main()
{const char *path = "hello.txt";int fd = open(path,O_RDWR);if(fd < 0){perror("open file error");return -1;}//加写锁// if (setlock(fd,F_WRLCK)<0)// {//     perror("set lock error");//     close(fd);//     return -1; b // }while (setlock(fd,F_WRLCK)<0){perror("set lock error");sleep(1);}//写char buf[128] = "set write lock";write(fd,buf,strlen(buf));printf("write success\n");getchar();//解锁if(setlock(fd,F_UNLCK) < 0){perror("unlock error");close(fd);return -1;}close(fd);}

读锁共享锁示例

加锁后还能读,另一个进程也可以(新开终端模拟)

#include <stdio.h>
#include <unistd.h>
#include <fcntl.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <string.h>// 设置文件锁
int setlock(int fd, short locktype) {struct flock lock = {0};lock.l_type = locktype;      // 锁类型(读锁、写锁、解锁)lock.l_whence = SEEK_SET;    // 从文件开头开始lock.l_start = 0;           // 起始偏移量lock.l_len = 0;             // 0 表示锁整个文件lock.l_pid = getpid();      // 当前进程的进程号// 设置锁(非阻塞模式)int res = fcntl(fd, F_SETLK, &lock);if (res < 0) {return -1; // 加锁失败}return 0; // 加锁成功
}int main() {const char *path = "testfile.txt";int fd = open(path, O_RDWR); // 打开文件if (fd < 0) {perror("open file error");return -1;}// 加读锁(共享锁)printf("Trying to set read lock...\n");if (setlock(fd, F_RDLCK) < 0) {perror("set read lock error");close(fd);return -1;}printf("Read lock set successfully!\n");// 读取文件内容char buf[128] = {0};lseek(fd, 0, SEEK_SET); // 将文件指针移动到开头read(fd, buf, sizeof(buf) - 1);printf("File content: %s\n", buf);// 模拟读操作printf("Reading file... Press Enter to unlock.\n");getchar();// 解锁printf("Unlocking file...\n");if (setlock(fd, F_UNLCK) < 0) {perror("unlock error");close(fd);return -1;}printf("File unlocked.\n");close(fd); // 关闭文件return 0;
}

相关文章:

【Linux系统编程】基本IO函数

目录 1、open 函数2、create 函数3、write 函数4、read 函数5、lseek 函数6、access 函数7、unlink 函数8、remove 函数9、fcntl 函数写锁互斥锁示例读锁共享锁示例 1、open 函数 头文件 #include<sys/types.h> #include<sys/stat.h>#include<fcntl.h>…...

Deepseek应用技巧-chatbox搭建前端问答

目标&#xff1a;书接上回&#xff0c;由于本地私有化部署了deepseek的大模型&#xff0c;那怎么能够投入生产呢&#xff0c;那就必须有一个前端的应用界面&#xff0c;好在已经有很多的前人已经帮我们把前段应用给搭建好了&#xff0c;我们使用就可以啦&#xff0c;今天我们就…...

OpenAI API模型ChatGPT各模型功能对比,o1、o1Pro、GPT-4o、GPT-4.5调用次数限制附ChatGPT订阅教程

本文包含OpenAI API模型对比页面以及ChatGPT各模型功能对比表 - 截至2025最新整理数据&#xff1a;包含模型分类及描述&#xff1b;调用次数限制&#xff1b; 包含模型的类型有&#xff1a; Chat 模型&#xff08;如 GPT-4o、GPT-4.5、GPT-4&#xff09;专注于对话&#xff0c…...

Fast DDS Security--秘钥交换

Fast DDS Security模块中默认使用Diffie-Hellman算法进行秘钥交换。Diffie-Hellman 算法&#xff08;简称 DH 算法&#xff09;是一个非常重要的加密协议&#xff0c;用于在不安全的通信通道中安全地交换密钥。该算法通过利用数学中的离散对数问题来生成共享密钥&#xff0c;使…...

从0开始的操作系统手搓教程33:挂载我们的文件系统

目录 代码实现 添加到初始化上 上电看现象 挂载分区可能是一些朋友不理解的——实际上挂载就是将我们的文件系统封装好了的设备&#xff08;硬盘啊&#xff0c;SD卡啊&#xff0c;U盘啊等等&#xff09;&#xff0c;挂到我们的默认分区路径下。这样我们就能访问到了&#xff…...

基于muduo+mysql+jsoncpp的简易HTTPWebServer

一、项目介绍 本项目基于C语言、陈硕老师的muduo网络库、mysql数据库以及jsoncpp&#xff0c;服务器监听两个端口&#xff0c;一个端口用于处理http请求&#xff0c;另一个端口用于处理发送来的json数据。 此项目在实现时&#xff0c;识别出车牌后打包为json数据发送给后端服务…...

【Go学习实战】03-2-博客查询及登录

【Go学习实战】03-2-博客查询及登录 读取数据库数据初始化数据库首页真实数据分类查询分类查询测试 文章查询文章查询测试 分类文章列表测试 登录功能登录页面登录接口获取json参数登录失败测试 md5加密jwt工具 登录成功测试 文章详情测试 读取数据库数据 因为我们之前的数据都…...

《Python实战进阶》No20: 网络爬虫开发:Scrapy框架详解

No20: 网络爬虫开发&#xff1a;Scrapy框架详解 摘要 本文深入解析Scrapy核心架构&#xff0c;通过中间件链式处理、布隆过滤器增量爬取、Splash动态渲染、分布式指纹策略四大核心技术&#xff0c;结合政府数据爬取与动态API逆向工程实战案例&#xff0c;构建企业级爬虫系统。…...

2021 年 9 月青少年软编等考 C 语言六级真题解析

目录 T1. 合法出栈序列思路分析T2. 奇怪的括号思路分析T3. 区间合并思路分析T4. 双端队列思路分析T1. 合法出栈序列 题目链接:SOJ D1110 给定一个由不同小写字母构成的长度不超过 8 8 8 的字符串 x x x,现在要将该字符串的字符依次压入栈中,然后再全部弹出。要求左边的字…...

Linux:多线程(单例模式,其他常见的锁,读者写者问题)

目录 单例模式 什么是设计模式 单例模式介绍 饿汉实现方式和懒汉实现方式 其他常见的各种锁 自旋锁 读者写者问题 逻辑过程 接口介绍 单例模式 什么是设计模式 设计模式就是一些大佬在编写代码的过程中&#xff0c;针对一些经典常见场景&#xff0c;给定对应解决方案&…...

shell 脚本的编写学习

学习编写 Shell 脚本是 Linux/Unix 系统管理和自动化的一个非常有用的技能。Shell 脚本是一些 Shell 命令的集合&#xff0c;用户可以用它来自动执行任务、简化工作流程、管理系统等。下面是一个 Shell 脚本学习的入门指南&#xff1a; 1. Shell 脚本基础 Shell 脚本通常是以…...

【氮化镓】高输入功率应力诱导的GaN 在下的退化LNA退化

2019年,中国工程物理研究院电子工程研究所的Tong等人基于实验与第一性原理计算方法,研究了Ka波段GaN低噪声放大器(LNA)在高输入功率应力下的退化机制。实验结果表明,在27 GHz下施加1 W连续波(CW)输入功率应力后,LNA的增益下降约1 dB,噪声系数(NF)增加约0.7 dB。进一…...

根据开始和结束日期,获取每一天和每个月的开始和结束日期的list

获取开始日期与结束日期之间每天的list /*** 根据传入的开始时间和结束时间,筛选出所有的天的list;** param startTime* param endTime*/public Map<String, List<String>> fetchDayListBetweenStartAndEnd(String startTime, String endTime) {// 创建mapMap<…...

Javaweb后端文件上传@value注解

文件本地存储磁盘 阿里云oss准备工作 阿里云oss入门程序 要重启一下idea&#xff0c;上面有cmd 阿里云oss案例集成 优化 用spring中的value注解...

git规范提交之commitizen conventional-changelog-cli 安装

一、引言 使用规范的提交信息可以让项目更加模块化、易于维护和理解&#xff0c;同时也便于自动化工具&#xff08;如发布工具或 Changelog 生成器&#xff09;解析和处理提交记录。 通过编写符合规范的提交消息&#xff0c;可以让团队和协作者更好地理解项目的变更历史和版本…...

Java/Kotlin逆向基础与Smali语法精解

1. 法律警示与道德边界 1.1 司法判例深度剖析 案例一&#xff1a;2021年某游戏外挂团伙刑事案 犯罪手法&#xff1a;逆向《王者荣耀》通信协议&#xff0c;修改战斗数据包 技术细节&#xff1a;Hook libil2cpp.so的SendPacket函数 量刑依据&#xff1a;非法经营罪&#xff…...

非软件开发项目快速上手:14款管理软件精选

文章介绍了以下14款项目管理系统&#xff1a;1.Worktile&#xff1b;2.Teambition&#xff1b;3.Microsoft Project&#xff1b;4.Forbes&#xff1b;5.WorkOtter&#xff1b;6.Trello&#xff1b;7.Smartsheet&#xff1b;8.Taiga&#xff1b;9.ClickUp&#xff1b;10.Monday.…...

Redis四种模式在Spring Boot框架下的配置

在Spring Boot框架下配置Redis的四种模式&#xff08;单机模式、主从模式、哨兵模式、集群模式&#xff09;可以通过以下方式实现&#xff1a; 1. 单机模式 在application.properties或application.yml中配置Redis的连接信息&#xff1a; # application.properties spring.redi…...

夸父工具箱(安卓版) 手机超强工具箱

如今&#xff0c;人们的互联网活动日益频繁&#xff0c;导致手机内存即便频繁清理&#xff0c;也会莫名其妙地迅速填满&#xff0c;许多无用的垃圾信息悄然占据空间。那么&#xff0c;如何有效应对这一难题呢&#xff1f;答案就是今天新推出的这款工具软件&#xff0c;它能从根…...

混元图生视频-腾讯混元开源的图生视频模型

混元图生视频是什么 混元图生视频是腾讯混元推出的开源图生视频模型&#xff0c;用户可以通过上传一张图片进行简短描述&#xff0c;让图片动起来生成5秒的短视频。模型支持对口型、动作驱动和背景音效自动生成等功能。模型适用于写实、动漫和CGI等多种角色和场景&#xff0c;…...

从零开始打造一个通用的 Vue 卡片组件

前言 大家好&#xff0c;最近在做项目的时候发现我们系统里到处都是各种卡片样式的 UI 元素&#xff0c;每次都要重写一遍真的很烦。于是我花了点时间&#xff0c;封装了一个通用的卡片组件&#xff0c;今天就来分享一下我的开发思路和实现过程。希望能对大家有所帮助&#xf…...

选择排序算法OpenMP并行优化

一 选择排序算法原理 时间复杂度,O(n 2)。 每次从未排序序列中选择最小元素,交换到已排序序列末尾。 二 具体步骤 1)初始状态 已排序区间为空,未排序区间为[0,n-1]。 2)第i次迭代 在未排序区间[i, n-1]中找最小值索引min_idx 交换arr[i]与arr[min_idx]。 3)重复…...

Debian系统grub新增启动项

参考链接 给grub添加自定义启动项_linux grub定制 启动项名称自定义-CSDN博客 www.cnblogs.com 1. boot里面的grub.cfg 使用vim打开boot里面的grub.cfg sudo vim /boot/grub/grub.cfg 这时候会看到文件最上方的提示 2. 真正配置grub的文件 从刚才看到的文件提示中&#x…...

VSCode快捷键整理

VSCode快捷键整理 文章目录 VSCode快捷键整理1-VSCode 常用快捷键1-界面操作2-单词移动3-删除操作4-编程相关5-多光标操作6-文件、符号、函数跳转7-鼠标操作8-自动补全操作9-代码折叠操作 1-VSCode 常用快捷键 1-界面操作 文件资源管理器&#xff1a;Ctrl Shift E 跨文件搜…...

刘火良 FreeRTOS内核实现与应用之1——列表学习

重要数据 节点的命名都以_ITEM后缀进行&#xff0c;链表取消了后缀&#xff0c;直接LIST 普通的节点数据类型 /* 节点结构体定义 */ struct xLIST_ITEM { TickType_t xItemValue; /* 辅助值&#xff0c;用于帮助节点做顺序排列 */ struct xLIST_I…...

本地部署Navidrome个人云音乐平台随时随地畅听本地音乐文件

文章目录 前言1. 安装Docker2. 创建并启动Navidrome容器3. 公网远程访问本地Navidrome3.1 内网穿透工具安装3.2 创建远程连接公网地址3.3 使用固定公网地址远程访问 前言 今天我要给大家安利一个超酷的私有化音乐神器——Navidrome&#xff01;它不仅让你随时随地畅享本地音乐…...

数据集构建与训练前准备

训练数据集目录结构与格式 作者笨蛋学法&#xff0c;先将其公式化&#xff0c;后面逐步自己进行修改&#xff0c;读者觉得看不懂可以理解成&#xff0c;由结果去推过程&#xff0c;下面的这个yaml文件就是结果&#xff0c;我们去推需要的文件夹(名字可以不固定&#xff0c;但是…...

jenkins+ant+jmeter生成的测试报告空白

Jenkins能正常构建成功&#xff0c;但是打开Jenkins上的测试报告&#xff0c;则显示空白 在网上找了很多文章&#xff0c;结果跟别人对比测试报告的配置&#xff0c;发现自己跟别人写的不一样 所以跟着别人改&#xff0c;改成一样的再试试 结果&#xff0c;好家伙&#xff0…...

利用阿里云Atlas地区选择器与Plotly.js实现数据可视化与交互

在数据科学与可视化领域&#xff0c;交互式图表和地图应用越来越成为数据分析和展示的重要手段。本文将介绍如何结合阿里云Atlas地区选择器与Plotly.js&#xff0c;创建动态交互式的数据可视化应用。 一、阿里云Atlas地区选择器简介 阿里云Atlas是阿里云的一款数据可视化产品…...

行为级建模

1、结构化过程语句 verilog有两种结构化过程语句&#xff1a; always initial verilog本质上是并发的。 //声明初值//方法一 reg clk ; initialclk 1b0 ;//方法二 reg clk 1b0 ;2、过程赋值语句 阻塞赋值 非阻塞赋值 非阻塞赋值可以避免竞争&#xff1a;…...