【Linux文件IO】Linux中标准IO的API的描述和基本用法
Linux中标准IO的API的描述和基本用法
- 一、标准IO相关API
- 1、文件的打开和关闭
- 示例代码:
- 2、文件的读写
- 示例代码:
- 用标准IO(fread、fwrite)实现文件拷贝(任何文件均可拷贝)
- 3、文件偏移设置
- 示例代码:
- 4、fgets fputs fgetc fputc gets puts putchar getchar putc getc
- 示例代码:
- (1) fgets按行读取数据
- (2) fputs写入数据到文件
- (3) fgets和fputs另外一个功能(标准输入和标准输出)
- (4) fgetc读取一个字符和fputc写入一个字符
- 5、判断是否到达文件末尾
- 示例代码:
- 6、fprintf和fscanf()
- 示例代码:
- 7、主动刷新缓冲区
- 示例代码:
- 二、对比系统IO和标准IO的区别
- 1、
- 2、
- 3、
一、标准IO相关API
1、文件的打开和关闭
注意:
- 总共有6中打开模式,不能自创别的模式,比如 “rw” 是非法的。
注意: - fclose函数涉及内存释放,不可对同一个文件多次关闭。
示例代码:
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <stdio.h>
#include <string.h>
#include <errno.h>int main(int argc, char const *argv[])
{FILE * fp;// 以只读方式打开文件,要求文件必须存在// fp = fopen("1.txt", "r"); // 文件打开失败 提示: No such file or directory// 以读写方式打开文件,要求文件必须存在// fp = fopen("1.txt", "r+"); // 文件打开失败 提示: No such file or directory// 以只写方式打开文件,不存在就新建,存在则清空fp = fopen("1.txt", "w"); // if (fp == NULL){perror("文件打开失败\n");return -1;}// 关闭文件fclose(fp);return 0;
}
2、文件的读写
//按照数据块来读取数据
size_t fread(void *ptr, size_t size, size_t nmemb, FILE *stream);返回值(重点):成功 返回读取到的完整的数据块的个数失败 -1参数:ptr --》存放读取的内容size(重点) --》要读取的数据块大小,字节nmemb(重点) --》打算读取多少个数据块stream --》要读取的那个文件比如:read(fd,buf,100); fread(buf,50,2); //读取2个数据块,每个数据块50个字节fread(buf,20,5); //读取5个数据块,每个数据块20个字节fread(buf,10,10); //读取10个数据块,每个数据块10个字节fread(buf,1,100); //读取100个数据块,每个数据块1个字节 情况1:如果文件剩余的字节数>=100个字节,以上四种写法都可以成功读取100个字节区别就是返回值不同情况2:如果文件剩余的字节数<100个字节,以上四种写法都可以成功读取剩余所有的字节区别就是返回值不同size_t fwrite(const void *ptr, size_t size, size_t nmemb, FILE *stream);返回值(重点): 成功 nmemb是多少,返回值就是多少参数:ptr --》存放要写入的内容size(重点) --》要写入的数据块大小,字节nmemb(重点) --》打算写入多少个数据块stream --》要写入的那个文件总结:无论write还是fwrite写入的字节数搞多了,都会找垃圾凑够需要写的字节数fwrite第三个参数写的是多少,返回值就是多少
示例代码:
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <stdio.h>
#include <string.h>
#include <errno.h>/*fread返回值:返回完整数据块个数fwrite返回值:nmemb是多少,返回值就是多少
*/int main(int argc, char const *argv[])
{FILE *fp = fopen("1.txt", "r+");int ret = 0; if (fp == NULL){perror("打开文件失败\n");return -1;}char buf[20] = "helloword";// ret = fread(buf, 10, 1, fp); // 读取1个数据块,数据块大小为10个字节 读取的内容是:1234567890// fread(buf, 5, 2, fp); // 读取2个数据块,数据块大小为5个字节 读取的内容是:1234567890// ret = fread(buf, 1, 10, fp); // 读取10个数据块,数据块大小为1个字节 读取的内容是:1234567890// fread(buf, 2, 5, fp); // 读取5个数据块,数据块大小为2个字节 读取的内容是:1234567890// ret = fread(buf, 6, 2, fp);// printf("读取的内容是:%s\n", buf);// printf("fread的返回值ret:%d\n", ret);ret = fwrite(buf, 10, 1, fp);printf("fwrite的返回值ret:%d\n", ret);return 0;
}
用标准IO(fread、fwrite)实现文件拷贝(任何文件均可拷贝)
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <stdio.h>
#include <string.h>
#include <errno.h>int main(int argc, char const *argv[])
{char buf[100] = {0};int ret = 0;FILE *fp1 = fopen("1.txt", "r+");if (fp1 == NULL){perror("打开文件失败\n");return -1;}FILE *fp2 = fopen("new.txt", "w+");if (fp1 == NULL){perror("新建文件失败\n");return -1;}while (1){bzero(buf, 100);// 每次读取100字节,即读取100个数据块,每个数据块1字节ret = fread(buf, 1, 100, fp1); // 读取完成则退出循环if (ret == 0) {break;}// 写入到目标文件fwrite(buf, 1, ret, fp2);}fclose(fp1);fclose(fp2);return 0;
}
3、文件偏移设置
示例代码:
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <stdio.h>
#include <string.h>
#include <errno.h>int main(int argc, char const *argv[])
{char buf[100] = {0};int ret = 0;FILE *fp1 = fopen("1.txt", "r+");if (fp1 == NULL){perror("打开文件失败\n");return -1;}// 从起始位置往后偏移5个字节,返回值与lseek不一样,0:成功, -1:失败ret = fseek(fp1, 5, SEEK_SET);printf("fseek的返回值是:%d\n", ret); // fseek的返回值是:0// 获取当前光标距离起始位置的字节数printf("当前光标距离起始位置的字节数:%ld\n", ftell(fp1)); // 当前光标距离起始位置的字节数:5// 读取文件,从第六个字节开始读取fread(buf, 1, 5, fp1);// 偏移后读取的数据是:world 若读取数据有误,现在linux中手动删除(rm 1.txt)在新建(vim 1.txt)printf("偏移后读取的数据是:%s\n", buf); // 关闭文件fclose(fp1);return 0;
}
4、fgets fputs fgetc fputc gets puts putchar getchar putc getc
char *fgets(char *s, int size, FILE *stream); //按行读取数据,一次最多读取一行(遇到回车结束读取)返回值:成功 返回读取的一行数据的首地址失败 NULL参数:s --》存放读取到的一行数据size --》打算读取多少字节的数据stream --》要从哪个文件读取一行特点:假如一行只有10个字符fgets(buf,5,myfile); //只能读取4个有效字符,最后一个fgets会帮你填充\0fgets(buf,11,myfile); //前面10个是有效字符,第11个是\0fgets(buf,12,myfile); //前面11个是有效字符(会把回车\n读取,windows上的回车是\r\n),第12个是\0
int fputs(const char *s, FILE *stream); //往一个文件中写入字符串返回值:成功 >0 失败 -1 参数:s --》要写入的内容stream --》要写入的那个文件 fputs有局限性(char *),只能写入字符串,但是fwrite可以写任意类型(void *)的数据int fgetc(FILE *stream); //按字符读取数据,一次只能读取一个字节的数据返回值:读取到的那个字符的ASCII码值失败 -1
int fputc(int c, FILE *stream); //把c这个字符写入到stream表示的文件中char *gets(char *s); //只能读取键盘输入的字符串,把字符串保存到s中
int puts(const char *s) //把s这个字符串在标准输出(液晶屏)上打印出来int getc(FILE *stream); //按字符读取数据,一次只能读取一个字节的数据
int putc(int c, FILE *stream); //把c这个字符写入到stream表示的文件中int getchar(void); //从IO缓冲区读取一个字符
int putchar(int c); //把c代表的字符在液晶屏上打印出来
示例代码:
(1) fgets按行读取数据
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <stdio.h>
#include <string.h>
#include <errno.h>/*fgets按行读取文件特点:fgets遇到回车就结束读取,并且会把回车也读取出来特点: 假如一行只有10个字符fgets(buf,5,myfile); //只能读取4个有效字符,最后一个fgets会填充\0fgets(buf,11,myfile); //前面10个是有效字符,第11个是\0fgets(buf,12,myfile); //前面11个是有效字符(会把回车\n读取,windows上的回车是\r\n),第12个是\0
*/
int main(int argc, char const *argv[])
{char buf[100] = {0};int ret = 0;FILE *fp1 = fopen("1.txt", "r+");if (fp1 == NULL){perror("打开文件失败\n");return -1;}// 每一轮读取一行数据 // for (int i = 0; i < 3; i++)// {// bzero(buf, 0);// fgets(buf, 100, fp1);// printf("buf :%s\n", buf);// }
/*
原始数据:helloworld你好你最棒
执行结果:buf :helloworldbuf :你好buf :你最棒 */// 第二个参数需要设置到足够大,否则一直读取第一行数据直至读完才会读取第二行数据bzero(buf, 100);fgets(buf,5,fp1);printf("buf :%s\n", buf);bzero(buf, 100);fgets(buf,5,fp1);printf("buf :%s\n", buf);bzero(buf, 100);fgets(buf,5,fp1);printf("buf :%s\n", buf);
/*
原始数据:helloworldnihaonihaohelloworld
执行结果:buf :hellbuf :oworbuf :ld
*/// 关闭文件fclose(fp1);return 0;
}
(2) fputs写入数据到文件
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <stdio.h>
#include <string.h>
#include <errno.h>int main(int argc, char const *argv[])
{char buf[100] = {0};int ret = 0;FILE *fp1 = fopen("1.txt", "r+");if (fp1 == NULL){perror("打开文件失败\n");return -1;}// 写入字符串fputs("hello", fp1);fputs("world", fp1);fseek(fp1, 0, SEEK_SET);fread(buf, 1, 100, fp1);printf("buf:%s\n", buf);// 关闭文件fclose(fp1);return 0;
}
(3) fgets和fputs另外一个功能(标准输入和标准输出)
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <stdio.h>
#include <string.h>
#include <errno.h>int main(int argc, char const *argv[])
{char buf[100] = {0};// fgets读取键盘输入的字符串(标准输入)printf("fgets从键盘输入一个字符串:");fgets(buf, 100, stdin);// fputs写入字符串到液晶屏(标准输出)printf("fputs从液晶屏输出一个字符串:");fputs(buf, stdout);return 0;
}/*
执行结果:fgets从键盘输入一个字符串:nihaofputs从液晶屏输出一个字符串:nihao
*/
(4) fgetc读取一个字符和fputc写入一个字符
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <stdio.h>
#include <string.h>
#include <errno.h>int main(int argc, char const *argv[])
{char buf[100] = {0};int ret = 0;FILE *fp1 = fopen("1.txt", "r+");if (fp1 == NULL){perror("打开文件失败\n");return -1;}// 读取一个字节ret = fgetc(fp1);printf("读取到的内容:%c, %d\n", ret, ret); // 读取到的内容:h, 104fputc('#', fp1);fseek(fp1, 0, SEEK_SET);fread(buf, 1, 100, fp1);printf("写入#后的内容是:%s\n", buf); // 写入#后的内容是:h#lloworld// 关闭文件fclose(fp1);return 0;
}
5、判断是否到达文件末尾
int feof(FILE *stream);返回值:1 表示达到文件末尾
示例代码:
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <stdio.h>
#include <string.h>
#include <errno.h>int main(int argc, char const *argv[])
{char buf[100] = {0};FILE *fp = fopen("1.txt", "r+");if (fp == NULL){perror("打开文件失败\n");return -1;}while(1){bzero(buf, 100);char *ret = fgets(buf, 100, fp);printf("读取到一行的数据:%s\n", buf);// 方法1:通过fgets和fread的返回值判断// if (ret == NULL)// {// printf("读取完毕\n");// break;// }// 方法2:使用feof函数判断if (feof(fp) == 1){printf("读取完毕\n");break;}}fclose(fp);return 0;
}/* 执行结果:读取到一行的数据:h#lloworld读取到一行的数据:nihao读取到一行的数据:666666读取完毕 */
6、fprintf和fscanf()
sprintf 拼接字符串printf 打印字符串
int fprintf(FILE *stream, const char *format, ...); //按照指定格式,把数据合并写入到stream代表的文件中int fscanf(FILE *stream, const char *format, ...); //按照指定格式,把数据读取出来fscanf读取指定格式的数据
如果指定的格式是%s,fscanf会把整个文件内容都当成是字符串
示例代码:
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <stdio.h>
#include <string.h>
#include <errno.h>int main(int argc, char const *argv[])
{/* fprintf 把字符串拼接好写入指定的文件中 */char read_buf[100] = {0};char *buf = "hello";int year = 2025;float score = 99.9;FILE *fp = fopen("2.txt", "w+");if (fp == NULL){perror("打开文件失败\n");return -1;}fprintf(fp, "%s%d-%f", buf, year, score);// 写完后此时光标移至末尾,需要将光标重新移至开头fseek(fp, 0, SEEK_SET);// 读取文件fread(read_buf, 1, 100, fp);printf("read_buf:%s\n", read_buf); // read_buf:hello2025-99.900002// 关闭文件fclose(fp);/* fscanf 把文件中的内容读取并拆分 */char *write_buf = "2025-01-01";int y,m,d;FILE *fp2 = fopen("3.txt", "w+");if (fp2 == NULL){perror("打开文件失败\n");return -1;}// 写入文件fwrite(write_buf, 1, strlen(write_buf), fp2);// 写入文件时会将光标移至文件末尾。需要将光标重新移至开头fseek(fp2, 0, SEEK_SET);// 把文件中的内容读取并拆分fscanf(fp2, "%d-%d-%d", &y, &m, &d);printf("年:%d\n", y);printf("月:%d\n", m);printf("日:%d\n", d);return 0;
}
/*
执行结果:read_buf:hello2025-99.900002年:2025月:1日:1
*/
7、主动刷新缓冲区
正常情况下标准IO是带缓冲区:情况一:缓冲区满了,自动刷新情况二:缓冲区没有满,主函数return退出的时候也会自动刷新缓冲区情况三:fclose关闭文件的时候也会刷新缓冲区
int fflush(FILE *stream);返回值:成功:0 失败:-1
示例代码:
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <stdio.h>
#include <string.h>
#include <errno.h>int main(int argc, char const *argv[])
{int n = 0;FILE *fp = fopen("4.txt", "r+");if (fp == NULL){perror("打开文件失败\n");return -1;}while (1){fwrite("hello", 1, 5, fp);sleep(1);fflush(fp); // 主动刷新缓冲区}fclose(fp);// return 0;
}
二、对比系统IO和标准IO的区别
1、
- 系统IO采用文件描述符来表示文件
- 标准IO采用FILE*来表示文件
2、
系统IO 0 1 2#define STDIN_FILENO 0 标准输入--》键盘#define STDOUT_FILENO 1 标准输出--》液晶屏#define STDERR_FILENO 2 标准错误输出--》液晶屏标准IO stdin stdout stderrFILE *stdin; 标准输入--》键盘FILE *stdout; 标准输出--》液晶屏 FILE *stderr; 标准错误输出--》液晶屏
3、
- 系统IO没有缓冲区
- 标准IO带缓冲区
相关文章:
【Linux文件IO】Linux中标准IO的API的描述和基本用法
Linux中标准IO的API的描述和基本用法 一、标准IO相关API1、文件的打开和关闭示例代码: 2、文件的读写示例代码:用标准IO(fread、fwrite)实现文件拷贝(任何文件均可拷贝) 3、文件偏移设置示例代码: 4、fgets fputs fget…...
【netstat和ss】Windows和Linux下的,网络连接排查简单案例
网络连接排查利器:netstat与ss命令详解 初识netstat:Windows下的网络连接查看工具 需要查看本机的网络连接情况时,Windows系统提供了一个非常实用的命令:netstat。和findstr组合形成一个有用的组合命令: netstat -a…...
【WPF】MVVM模式实现数据绑定以及Command事件绑定
1.引用类 using System.ComponentModel2.创建Command自定义类 public class DelegateCommand : ICommand{public bool CanExecute(object parameter){if (CanExecuteFunc null)return true;return this.CanExecuteFunc(parameter);}public event EventHandler CanExecuteChan…...
Flutter快速搭建聊天
之前项目中使用的环信聊天,我们的App使用的Flutter开发的 。 所以,就使用的 em_chat_uikit ,这个是环信开发的Flutter版本的聊天。 一开始,我们也用的环信的聊天,是收费的,但是,后面就发现&…...
网络层之IP协议
在讨论传输层时, 我们都只讨论了发送方和接收方的问题, 而没有讨论中间的网络形态的问题. 也就是数据包如何从主机传送到主机的? 如图, 主机B发送数据到主机C, 发送报文需要进行路径选择, 主机B-> F-> G-> H-> C-> D -> 主机C 这条路径是如何被选择出来的?…...
【设计模式】策略模式(Strategy Pattern)详解
策略模式(Strategy Pattern)详解 一、策略模式的定义 策略模式(Strategy Pattern)是一种行为型设计模式,它定义了一组算法,将每个算法封装起来,并使它们可以相互替换,从而让算法的…...
Elasticsearch:构建 AI 驱动的搜索体验
Elasticsearch 介绍 当你开始使用 Elastic 时,你将使用 Elasticsearch Relevance Engine™(ESRE),它专为 AI 搜索应用程序提供支持。借助 ESRE,你可以利用一整套开发者工具,包括 Elastic 的文本搜索、向量…...
数据文件误删除,OceanBase中如何重建受影响的节点
当不慎误删数据文件且当前没有现成的可替换节点时,在OceanBase中,不必急于采取极端措施,可以考虑运用 server_permanent_offline_time 参数,来重建受影响的节点。 原理: server_permanent_offline_time 是 OceanBase数…...
MySQL面试专题
1.什么是BufferPool? Buffer Pool基本概念 Buffer Pool:缓冲池,简称BP。其作用是用来缓存表数据与索引数据,减少磁盘IO操作,提升效率。 Buffer Pool由缓存数据页(Page) 和 对缓存数据页进行描述的控制块 组成, 控制…...
Redmi Note 11 T pro + 刷入 LinegaOs 22.1 记录 手机已经解锁bl.
Redmi Note 11 T pro 刷入 LinegaOs 22.1 记录 手机已经解锁bl. 获取LIneagaOS源码, 以及https://github.com/xiaomi-mediatek-devs 这个组织提供的代码,非常感谢 环境要求: ubuntu 22.04 需要准备的依赖 sudo apt install git curl vim…...
Python+Requests+Pytest+YAML+Allure接口自动化框架
GitHub源码地址(详细注释):源码 调试项目python自主搭建:附项目源码 一、项目介绍 本项目是基于 PythonRequestsPytestYAMLAllure 搭建的 接口自动化测试框架,用于对 REST API 进行测试。 框架的主要特点包括&#…...
如何解决Redis缓存异常问题(雪崩、击穿、穿透)
引言 Redis作为一种高性能的内存数据库,被广泛应用于缓存系统的构建中。然而,在实际应用过程中,我们常常会遇到三种典型的缓存异常问题:缓存雪崩、缓存击穿和缓存穿透。这些问题如果处理不当,可能会导致系统性能下降&…...
如何使用 Postman 进行接口测试?
使用 Postman 这一工具,可以轻松地进行接口测试。以下是一份简单的使用教程,帮助你快速上手。 Postman 接口测试教程:详细步骤及操作技巧...
记一次线上环境JAR冲突导致程序报错org.springframework.web.util.NestedServletException
一、问题描述 有个文件导入功能,用到了Hutool 的加密解密功能,本地运行完全可以,但是线上报错:“org.springframework.web.util.NestedServletException: Handler dispatch failed; nested exception is java.lang.NoClassDefFou…...
VLAN实验
一:实验拓扑 二:实验需求 1、PC1和PC3所在接口为access接口,属于VLAN 2 2、PC2/4/5/6处于同一网段 其中PC2可以访问PC4/5/6 PC4可以访问PC5不能访问PC6 PC5不能访问PC6 3、PC1/3和PC2/4/5/6不在一个网段,且可以正常通讯 4、…...
FPGA中串行执行方式之状态机
FPGA中串行执行方式之状态机 在FPGA中,默认情况下,逻辑是并行执行的,因为FPGA的硬件资源是并行的。然而,在某些情况下,你可能需要某一段逻辑以串行方式执行。这可以通过以下几种方法实现:使用状态机(Finite State Machine, FSM)、使用计数器控制、使用流水线(Pipel…...
【常用的中间件】
中间件(Middleware)是位于客户端和服务器之间的软件层,用于处理客户端请求和服务器响应之间的各种任务。中间件可以提供多种功能,如负载均衡、消息队列、缓存、身份验证等。以下是常用的中间件及其作用: 1. 消息队列中…...
spring - 十二种事务失效场景
目录 编辑 一、方法内部调用 1、原理: 2、结论: 3、解决方法: 1. 增加一个service,把一个事务的方法移到新增加的service方法里面,然后进行注入再调用 2. 在自己类中注入自己 3. 通过AopContentent 二、访问权限不是pubilc 三、方法用final修饰 四、没有被spr…...
python脚本处理excel文件
1.对比perl和python 分别尝试用perl和python处理excel文件,发现perl的比较复杂,比如说read excel就有很多方式 Spreadsheet::Read use Spreadsheet::ParseExcel 不同的method,对应的取sheet的cell方式也不一样。更复杂的是处理含有中文内…...
C#基础学习(二)C#数组生存手册:从入门到“血压拉满“的奇妙旅程
作为一只C#萌新,当你试图用数组装下整个世界时,系统可能会温柔地弹出一句**"Index was outside the bounds of the array."**。别慌!这份求生指南将用段子教你玩转数组 一、数组是什么 数组简单来说就是由相同元素组成的一个集合&a…...
MySQL 性能优化方向
MySQL 性能优化是一个系统性的工作,涉及数据库设计、查询优化、索引优化、硬件配置等多个方面。以下是 MySQL 性能优化的主要方向和具体优化方案: 一、数据库设计优化 1. 合理设计表结构 规范化设计:避免数据冗余,确保数据一致性。适度反规范化:在查询频繁的场景下,适当…...
2025年- G26-Lc100-57.插入间隔(max、min)--java版
1.题目描述 题目翻译: 给定一个不重叠的区间阵列 intervals,其中intervals[i] [starti, endi]表示第i一个区间的起始位置和结束位置,并且intervals 按照起始位置starti升序排序。 另外,给定一个新的区间newInterval [start, e…...
Burp Suite HTTPS解密原理
HTTPS HTTPS是在HTTP的基础上增加了SSL/TLS协议,提供了数据的加密、完整性校验和身份认证等安全保障。HTTPS的工作过程可以分为两个阶段:握手阶段和数据传输阶段。 流程如下图所示: 通过上面的图可以看到,在TCP建立连接后会发起…...
【ESP32S3】esp32获取串口数据并通过http上传到前端
通过前面的学习(前面没发过,因为其实就是跑它的demo)了解到串口配置以及开启线程实现功能的工作流程,与此同时还有esp32作为STA节点,将数据通过http发送到服务器。 将这两者联合 其实是可以得到一个:esp32获…...
怎么查看linux是Ubuntu还是centos
要确定你的Linux系统是基于Ubuntu还是CentOS,可以通过几种不同的方法来进行判断。下面是一些常用的方法: 要快速判断 Linux 系统是 Ubuntu 还是 CentOS,可通过以下方法综合验证: 一、查看系统信息文件 1. /etc/os-release 文件…...
Qt进程间通信:QSharedMemory 使用详解
1. 什么是 QSharedMemory? QSharedMemory 是 Qt 中用于进程间共享内存的类。它允许多个进程共享一块内存区域,从而避免数据传输时的 IO 操作,提高通信速度。通过共享内存,多个进程可以直接读写这块内存,而无需经过文件…...
【day1】数据结构刷题 链表
一 反转链表 206. 反转链表 给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。 示例 1: 输入:head [1,2,3,4,5] 输出:[5,4,3,2,1]示例 2: 输入:head [1,2] 输出:[2,1]…...
使用redis设置店铺状态
知识点: 将前端传过来的status(0,1)通过redis对象以key,values值的形式存放在redis中。 #设置店铺状态 redisTemplate.opsForValue().set(KEY,status); #获取店铺状态 Integer status (Integer) redisTemplate.o…...
基于python+django的商城网站-电子商城管理系统源码+运行
基于 python 开发的电子商城网站,平台采用 B/S 结构,后端采用主流的 Python 语言进行开发,前端采用主流的 Vue.js 进行开发。该系统是给师弟做的课程作业。同学们可以拿去自用。学习问题可以留言哦。 整个平台包括前台和后台两个部分。 前台…...
深度解读 C 语言运算符:编程运算的核心工具
一、引言 在 C 语言的编程世界中,运算符是构建逻辑与运算的基石,它如同一位指挥家,精准地协调着程序中各种数据的操作与处理。C 语言丰富多样的运算符涵盖了算术、关系、逻辑、位运算、赋值以及其他杂项运算等多个领域,为开发者提…...
docker中间件部署
1.docker安装 # 1.卸载旧版本 yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \docker-engine# 2.需要的安装包 yum install -y yum-utils# 3.设置镜像的仓库 # 3.1.默认是国外的&#x…...
【Python Cookbook】字符串和文本(二)
字符串和文本(二) 6.字符串忽略大小写的搜索替换7.最短匹配模式8.多行匹配模式9.将 Unicode 文本标准化10.在正则式中使用 Unicode 6.字符串忽略大小写的搜索替换 你需要以忽略大小写的方式搜索与替换文本字符串。 为了在文本操作时忽略大小写…...
docker pull时报错:https://registry-1.docker.io/v2/
原文:https://www.cnblogs.com/sdgtxuyong/p/18647915 https://www.cnblogs.com/OneSeting/p/18532166 docker 换源,解决连接不上的问题。 编辑以下文件,不存在则创建: vim /etc/docker/daemon.json {"registry-mirrors&qu…...
DeepSeek助力文案,智能音箱如何改变你的生活?
你好,我是三桥君 你有没有为写智能音箱的宣传文案而抓耳挠腮过?三桥君在这方面可是有些感想,今天就来给你唠唠怎么用DeepSeek写出超赞的智能音箱宣传文案。 首先,你得给DeepSeek喂足“料”。这就好比做饭,你得准备好各…...
【机器学习】什么是随机森林?
什么是随机森林? 随机森林(Random Forest)是一种集成学习方法,它通过组合多个决策树来提高预测的准确性和鲁棒性。可以把随机森林看作是“森林”,而森林中的每棵树就是一个决策树。每棵树独立地做出预测,最…...
Nature Machine Intelligence 嵌入式大语言模型使机器人能够在不可预测的环境中完成复杂的任务
近期英国爱丁堡大学发表Nature Machine Intelligence研究工作,提出了一种名为ELLMER(具身大型语言模型支持机器人)的创新框架,通过整合大型语言模型(如GPT-4)、检索增强生成(RAG)、视…...
[特殊字符] 2025蓝桥杯备赛Day13——P10984 [蓝桥杯 2023 国 Python A] 残缺的数字
🔍 2025蓝桥杯备赛Day13——P10984 [蓝桥杯 2023 国 Python A] 残缺的数字 🚀 题目速览 题目难度:⭐⭐⭐(需掌握位运算与组合数学) 考察重点:二进制状态处理、位运算、乘法原理、枚举 P10984 [蓝桥杯 2…...
【AcWing】算法基础课-数学知识
目录 1、质数 1.1 试除法判定质数 暴力解法 优化解法 1.2 分解质因数(试除法) 暴力解法 优化解法 1.3 筛质数 朴素筛法(nlogn) 埃氏筛法(nloglogn) 线性筛法(n) 2、约数 2.1 试除法求约数 2.2 约数个数 2.3 约数之和 2.4 最大公约数 实现方法一 实现方法二 …...
JVM常见概念之条件移动
问题 当我们有分支频率数据时,有什么有趣的技巧可以做吗?什么是条件移动? 基础知识 如果您需要在来自一个分支的两个结果之间进行选择,那么您可以在 ISA 级别做两件不同的事情。 首先,你可以创建一个分支ÿ…...
k8s存储介绍(二)Secret
Kubernetes(K8s)提供了一种安全的方式来存储和管理敏感信息,如密码、OAuth 令牌和 SSH 密钥,这就是 Secret。使用 Secret 可以避免将敏感数据硬编码到 Pod 规范或容器镜像中,从而提高安全性和可管理性。 1. Secret 的…...
Css布局-常规流笔记
https://developer.mozilla.org/zh-CN/docs/Learn/CSS/CSS_layout/Normal_Floworghttps://developer.mozilla.org/zh-CN/docs/Learn/CSS/CSS_layout/Normal_Flow 前言 常规流布局是html元素默认布局,凡是没有设置过css布局的html元素,默认布局方式称为常…...
Linux系统管理与编程08:任务驱动综合应用
兰生幽谷,不为莫服而不芳; 君子行义,不为莫知而止休。 [环境] windows11、centos7.9.2207、zabbix6、MobaXterm、Internet环境 [要求] zabbix6.0安装环境:Lamp(linux httpd mysql8.0 php) [步骤] 3 …...
基于 OCO - 2 氧气 A 带辐射数据与地面台站气压观测数据构建近地面气压监测算法方案
基于 OCO - 2 氧气 A 带辐射数据与地面台站气压观测数据构建近地面气压监测算法方案 一、数据获取与准备 (一)OCO - 2 氧气 A 带辐射数据 数据下载:从 OCO - 2 官方数据发布平台(如 NASA 的相关数据存储库),按照研究所需的时间范围(例如,近 5 年的数据以获取足够的样本…...
Linux centos7 虚拟用户访问脚本
下面是脚本: #!/bin/bash #function:创建 vsftpd 虚拟用户脚本 #author: 20250324 IT小旋风# 判断是否是 root 用户 if [ "$USER" ! "root" ]; thenecho "不是 root 用户,无法进行安装操作"exit 1 fi# 关闭防火墙 system…...
HTTP 协议中请求与响应的详细解析
前言:HTTP(Hypertext Transfer Protocol,超文本传输协议)是用于在互联网上传输超文本的协议 --由一个请求和响应组成,一个完整的 HTTP 请求由请求行(Request Line)、请求头(Headers&…...
Collectors.toMap / list 转 map
前言 略 Collectors.toMap List<User> userList ...; Map<Long, User> userMap userList.stream().collect(Collectors.toMap(User::getUserId, Function.identity()));假如id存在重复值,则会报错Duplicate key xxx, 解决方案 两个重复id中&#…...
根据模板将 Excel 明细数据生成 PDF 文档 | PDF实现邮件合并功能
在日常办公中,我们常常会面临这样的需求:依据特定的模板,把 Excel 里的每一条数据转化为单独的 PDF 文档,且这些 PDF 文档中的部分内容会根据 Excel 数据动态变化。这一功能不仅能高效完成任务,还支持图片的动态替换&a…...
<KeepAlive>和<keep-alive>有什么区别
在不同的前端技术框架里,<KeepAlive> 和 <keep-alive> 有着不同的含义与使用场景,下面分别从 Vue 2 和 Vue 3 来为你详细介绍它们的区别。 Vue 2 中的 <keep-alive> 在 Vue 2 里,<keep-alive> 属于内置组件&#x…...
vscode正则表达式使用
小标题 ^\d.\d.\d\s.*$ ^表示匹配字符串的开头。\d\.\d\.\d表示匹配一到多个数字,接着一个小数点,再接着一到多个数字,然后又一个小数点和一到多个数字,用来匹配类似 “2.1.1” 这样的标题号部分。\s表示匹配一个空格。.*表示匹配…...
【LeetCode 题解】算法:4.寻找两个正序数组的中位数
1. 引言:挑战 LeetCode 经典算法题 在算法这片广袤无垠的天地里,一道道经典题目宛如夜空中熠熠生辉的星辰,持续吸引着开发者们投身其中,不断探索。今天,我们继续将目光聚焦于 LeetCode 平台上一道极具代表性的题目&am…...