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

Linux系统编程_文件编程第1天:打开、写入、读取、关闭文件等编程

1. 文件编程概述(399.1)

  • 内容超多:
    • 文件系统原理及访问机制
    • 文件在内核中的管理机制
    • 什么是文件信息节点inode
    • 文件的共享
    • 文件权限,各种用户对其权限
    • 。。。。。。
  • 应用为王,如:
    • 账单
    • 游戏进度
    • 配置文件等
  • 关心如何用代码操作文件,实现文件创建、打开、编辑等自动化执行
  • Windows 如何手动修改文件,比如写一个 word 文档:
    • 打开/创建文档、编辑文档、保存文档、关闭文档
  • 计算机如何帮助我们自动化完成以上操作?
  • 操作系统提供了一系列的 API,如 Linux 系统:
    • 打开 open
    • 读写 write /read
    • 光标定位 lseek
    • 关闭 close

2. 文件打开及创建(400.2)

打开/创建文件

在这里插入图片描述
在这里插入图片描述

参数说明

在这里插入图片描述

  • int 返回值:文件描述符,应为小的非负整数
  • Pathname:要打开的文件名(含路径,缺省为当前路径)
  • Flags:
    • O_RDONLY 只读打开
    • O_WRONLY 只写打开
    • O_RDWR 可读可写打开
      • 当我们附带了权限后,打开的文件就只能按照这种权限来操作。
      • 以上这三个常数中应当指定一个。
    • 下列常数是可选择的:
      • O_CREAT:若文件不存在则创建它。使用此选项时,需要同时说明第三个参数 mode(0600),用其说明该新文件的存取许可权限
      • O_EXCL:如果同时指定了O_CREAT,而文件已经存在,则出错
      • O_APPEND:每次写时都加到文件的尾端
      • O_TRUNC:属性去打开文件时,如果这个文件中本来是有内容的,而且为只读或只写成功打开,则将其长度截短为 0。
  • Mode:一定是在 flags 中使用了 O_CREAT 标志,mode 记录待创建的文件的访问权限
  • FILE/demo.c
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>//以上三行为open函数需包含的头文件
#include <stdio.h>//printf函数需包含的头文件
int main(){int fd;//文件描述符,索引值fd = open("./file1",O_RDWR);//文件名(含路径),可读可写权限printf("fd = %d\n",fd);return 0;
}

在这里插入图片描述

  • FILE/demo2.c
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>//以上三行为open函数需包含的头文件
#include <stdio.h>//printf函数需包含的头文件int main(){int fd;fd = open("./file1",O_RDWR);printf("fd = %d\n",fd);if(fd == -1){printf("open file1 failed\n");fd = open("./file1",O_RDWR|O_CREAT,0600);//若文件不存在则创建if(fd > 0){printf("fd = %d\n",fd);printf("create file1 success!\n");}}return 0;
}

在这里插入图片描述
在这里插入图片描述

  • -rwx:
    • -:普通文件
    • r:可读
    • w:可写
    • x:可执行
      在这里插入图片描述

3. 文件写入操作编程(401.3)

  • 查看函数原型
    在这里插入图片描述

写入文件

在这里插入图片描述

  • write 返回的是写入的字节数
  • FILE/demo3.c
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>//以上三行为open函数需包含的头文件
#include <stdio.h>//printf函数需包含的头文件
#include <unistd.h>//write函数需包含的头文件
#include <string.h>//strlen的头文件int main(){int fd;char *buf = "Jessie is very kind.";fd = open("./file1",O_RDWR);printf("fd = %d\n",fd);if(fd == -1){printf("open file1 failed\n");fd = open("./file1",O_RDWR|O_CREAT,0600);//若文件不存在则创建if(fd > 0){printf("fd = %d\n",fd);printf("create file1 success!\n");}}printf("open success : fd = %d\n",fd);//打开文件//ssize_t write(int fd, const void *buf, size_t count);//write的函数原型write(fd,buf,strlen(buf));//写入文件//在Linux中指针是固定8个字节,所以不能用sizeof//stlen计算字符串长度close(fd);//关闭文件return 0;
}

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

4. 文件读取操作(402.4)

读取文件

在这里插入图片描述

  • read 返回的是读取的字节数
    在这里插入图片描述
  • FILE/demo4.c
  • FILE/demo5.c
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>//以上三行为open函数需包含的头文件
#include <stdio.h>//printf函数需包含的头文件
#include <unistd.h>//write函数需包含的头文件
#include <string.h>//strlen的头文件
#include <stdlib.h>//malloc的头文件int main(){int fd;char *buf = "Jessie is very kind.";fd = open("./file1",O_RDWR);printf("fd = %d\n",fd);if(fd == -1){printf("open file1 failed\n");fd = open("./file1",O_RDWR|O_CREAT,0600);//若文件不存在则创建if(fd > 0){printf("fd = %d\n",fd);printf("create file1 success!\n");}}printf("open success : fd = %d\n",fd);//打开文件//ssize_t write(int fd, const void *buf, size_t count);int n_write = write(fd,buf,strlen(buf));//存储在fd中写入所有的buf后的字节数if(n_write != -1){printf("write %d byte to file1\n",n_write);}close(fd);fd = open("./file1",O_RDWR);//重新打开文件,光标移至头char *readBuf;readBuf = (char *)malloc(sizeof(char)*n_write + 1);	//ssize_t read(int fd, void *buf, size_t count);//read的函数原型int n_read = read(fd,readBuf,n_write);//存储从fd中读出的readBuf的所有的字节数printf("read %d ,context:%s\n",n_read,readBuf);close(fd);//关闭文件return 0;
}

5. 文件光标移动操作(403.5)

将文件读写指针相对whence移动offset个字节

在这里插入图片描述
在这里插入图片描述

  • FILE/demo6.c(打开、写入、定位光标、读取数据)
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>//以上三行为open函数需包含的头文件
#include <stdio.h>//printf函数需包含的头文件
#include <unistd.h>//write函数需包含的头文件
#include <string.h>//strlen的头文件
#include <stdlib.h>//malloc的头文件int main(){int fd;char *buf = "Jessie is very kind.";fd = open("./file1",O_RDWR);printf("fd = %d\n",fd);if(fd == -1){printf("open file1 failed\n");fd = open("./file1",O_RDWR|O_CREAT,0600);//若文件不存在则创建if(fd > 0){printf("fd = %d\n",fd);printf("create file1 success!\n");}}printf("open success : fd = %d\n",fd);//打开文件//ssize_t write(int fd, const void *buf, size_t count);//write的函数原型int n_write = write(fd,buf,strlen(buf));//存储在fd中写入所有的buf后的字节数if(n_write != -1){printf("write %d byte to file1\n",n_write);}//close(fd);//fd = open("./file1",O_RDWR);//重新打开文件,光标移至头char *readBuf;readBuf = (char *)malloc(sizeof(char)*n_write + 1);	//ssize_t read(int fd, void *buf, size_t count);//read的函数原型//off_t lseek(int fd, off_t offset, int whence);//lseek的函数原型//lseek(fd,0,SEEK_SET);lseek(fd,-20,SEEK_CUR);//lseek(fd,-20,SEEK_END);int n_read = read(fd,readBuf,n_write);//存储从fd中读出的readBuf的所有的字节数printf("read %d ,context:%s\n",n_read,readBuf);close(fd);//关闭文件return 0;
}
  • FILE/demo7.c(lseek返回有多少个字节)
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>//以上三行为open函数需包含的头文件
#include <stdio.h>//printf函数需包含的头文件
#include <unistd.h>//write函数需包含的头文件
#include <string.h>//strlen的头文件
#include <stdlib.h>//malloc的头文件int main(){int fd;char *buf = "Jessie is very kind.";fd = open("./file1",O_RDWR);int filesize = lseek(fd,0,SEEK_END);//lseek返回多少个字节printf("file's size is :%d\n",filesize);close(fd);//关闭文件return 0;
}

关闭文件

在这里插入图片描述

6. 文件打开创建的补充(404.6)

O_EXCL:如果同时指定了 OCREAT,而文件已经存在,则出错(即返回-1)

  • FILE/demo8.c
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <stdio.h>int main(){int fd;fd = open("./file1",O_RDWR|O_CREAT|O_EXCL,0600);//若文件不存在则创建,已存在则出错if(fd == -1){printf("File1 exists.\n");}return 0;
}

O_APPEND:每次写时都加到文件的尾端(另起一行)

  • FILE/demo9.c
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>//以上三行为open函数需包含的头文件
#include <stdio.h>//printf函数需包含的头文件
#include <unistd.h>//write函数需包含的头文件
#include <string.h>//strlen的头文件
#include <stdlib.h>//malloc的头文件int main(){int fd;char *buf = "Jessie is very kind.";//fd = open("./file1",O_RDWR);fd = open("./file1",O_RDWR|O_APPEND);//另起一行添加字符printf("open success : fd = %d\n",fd);//打开文件int n_write = write(fd,buf,strlen(buf));//存储在fd中写入所有的buf后的字节数if(n_write != -1){printf("write %d byte to file1\n",n_write);}close(fd);//关闭文件return 0;
}
  • 有 O_APPEND 时:另起一行添加
    在这里插入图片描述
  • 无 O_APPEND 时:覆盖原先对应位置的字符,保留后边的字符
    在这里插入图片描述

O_TRUNC:去打开文件时,如果这个文件中本来是有内容的,而且为只读或只写成功打开,则将其长度截短为0(即删除原来的所有字符)

  • FILE/demo10.c
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>//以上三行为open函数需包含的头文件
#include <stdio.h>//printf函数需包含的头文件
#include <unistd.h>//write函数需包含的头文件
#include <string.h>//strlen的头文件
#include <stdlib.h>//malloc的头文件int main(){int fd;char *buf = "Jessie.";fd = open("./file1",O_RDWR|O_TRUNC);//打开已有文件时,清空字符printf("open success : fd = %d\n",fd);//打开文件int n_write = write(fd,buf,strlen(buf));//存储在fd中写入所有的buf后的字节数if(n_write != -1){printf("write %d byte to file1\n",n_write);}close(fd);//关闭文件return 0;
}

在这里插入图片描述

创建文件creat函数

在这里插入图片描述

  • FILE/demo11.c
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>//以上三行为open函数需包含的头文件
#include <stdio.h>//printf函数需包含的头文件
#include <unistd.h>//write函数需包含的头文件
#include <string.h>//strlen的头文件
#include <stdlib.h>//malloc的头文件int main(){int fd;//int creat(const char *pathname, mode_t mode);fd = creat("./file2",S_IRWXU);return 0;
}

在这里插入图片描述

7. 文件操作原理简述(审核不过./7)

文件描述符

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

  • FILE/demo12.c
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <stdio.h>
#include <unistd.h>
#include <string.h>
#include <stdlib.h>int main(){int fd;char readBuf[128];int n_read = read(0,readBuf,5);//从标准输入(键盘)读int n_write = write(1,readBuf,strlen(readBuf));//写到标准输出(UNIX shell)printf("\ndone!\n");return 0;
}

文件编程的一般步骤

  • 打开/创建文件、读取文件/写入文件、关闭文件
    在这里插入图片描述

在这里插入图片描述

Linux文件管理简述

在这里插入图片描述

8. 文件操作小应用之实现cp指令(405.8)

在这里插入图片描述

  • FILE/test1.c(先做测试)
#include <stdio.h>int main(int argc, char **argv){printf("totol params: %d\n",argc);//参数总数printf("No.1 params :%s\n",argv[0]);//参数名称,数组的形式//a.outprintf("No.2 params :%s\n",argv[1]);//srcprintf("No.3 params :%s\n",argv[2]);//des()return 0;
}

在这里插入图片描述

  • FILE/demo13.c( 实现linux cp命令的代码)
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <stdio.h>
#include <unistd.h>
#include <string.h>
#include <stdlib.h>int main(int argc, char **argv){int fdSrc;//源文件描述符int fdDes;//目标文件描述符char *readBuf=NULL;if(argc != 3){//对参数个数的判断printf("pararm error\n");exit(-1);}fdSrc = open(argv[1],O_RDWR);//打开源文件int size = lseek(fdSrc,0,SEEK_END);//算出源文件的字节大小readBuf=(char *)malloc(sizeof(char)*size + 8);//开辟比源文件多8个字节的大小lseek(fdSrc,0,SEEK_SET);//光标移至源文件内容的头int n_read = read(fdSrc, readBuf, size);//读源文件到readBuf,要用sizefdDes = open(argv[2],O_RDWR|O_CREAT|O_TRUNC,0600);//打开/创建目标文件,目标文件已存在时清空内容int n_write = write(fdDes,readBuf,strlen(readBuf));//将readBuf写入目标文件close(fdSrc);//关闭源文件close(fdDes);//关闭目标文件return 0;
}

在这里插入图片描述

9. 解决上节课中的隐藏bug(406.9)

  • FILE/demo13.c( 实现linux cp命令的代码)
int n_read = read(fdSrc, readBuf, size);//读源文件到readBuf,要用sizefdDes = open(argv[2],O_RDWR|O_CREAT|O_TRUNC,0600);//打开/创建目标文件,目标文件已存在时清空内容

相关文章:

Linux系统编程_文件编程第1天:打开、写入、读取、关闭文件等编程

1. 文件编程概述&#xff08;399.1&#xff09; 内容超多&#xff1a; 文件系统原理及访问机制文件在内核中的管理机制什么是文件信息节点inode文件的共享文件权限&#xff0c;各种用户对其权限。。。。。。 应用为王&#xff0c;如&#xff1a; 账单游戏进度配置文件等 关心如…...

scapy构造ND报文

控制报文之&#xff1a;找邻居报文 什么是ND报文 ND报文是指网络中的 Neighbor Discovery&#xff08;ND&#xff09;控制报文。Neighbor Discovery 是 IPv6 网络中的一种协议&#xff0c;它用于管理网络节点之间的邻居关系、地址解析、路由缓存维护和自动配置等任务。ND 协议…...

c++设计模式之单例设计模式

&#x1f482; 个人主页:[pp不会算法v](https://blog.csdn.net/weixin_73548574?spm1011.2415.3001.5343) &#x1f91f; 版权: 本文由【pp不会算法^v^】原创、在CSDN首发、需要转载请联系博主 &#x1f4ac; 如果文章对你有帮助、欢迎关注、点赞、收藏(一键三连)和订阅专栏哦…...

App自动化测试环境搭建

目录 1、java jdk安装 2、node.js安装 3、安装模拟器安装 4、Android SDK 安装 5、Appium-Server安装 6、appium客户端安装  7、Appium-Python-Client安装 只做记录和注意点&#xff0c;详细内容不做解释 环境&#xff1a;winappium夜神模拟器python 需要用到的工具&a…...

win10搭建gtest测试环境+vs2019

首先是下载gtest&#xff0c;这个我已经放在了博客上方资源绑定处&#xff0c;这个适用于win10vs版本&#xff0c;关于liunx版本的不能用这个。 或者百度网盘链接&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/15m62KAJ29vNe1mrmAcmehA 提取码&#xff1a;vfxz 下…...

【代码随想录】算法训练营 第二天 第一章 数组 Part 2

977. 有序数组的平方 题目 暴力解法 思路 原地更新所有数组元素为其平方数后&#xff0c;再使用sort函数排序&#xff0c;对vector使用sort函数时&#xff0c;两个参数分别是vector的起始元素和终止元素。 代码 class Solution { public:vector<int> sortedSquares(…...

在深度学习中,累计不同批次的损失估计总体损失

在深度学习中&#xff0c;累计不同批次的损失估计总体损失 在深度学习训练模型的过程中&#xff0c;通常会通过计算不同批次间的损失和&#xff0c;当作模型在这个训练集上的总体损失&#xff0c;这种做法是否具有可行性呢&#xff1f; 什么是总体损失? 总体损失是计算模型在…...

论文导读|八月下旬Operations Research文章精选:定价问题专题

编者按&#xff1a; ​ ​在“ Operations Research论文精选”中&#xff0c;我们有主题、有针对性地选择了Operations Research中一些有趣的文章&#xff0c;不仅对文章的内容进行了概括与点评&#xff0c;而且也对文章的结构进行了梳理&#xff0c;旨在激发广大读者的阅读兴…...

(三)Apache log4net™ 手册 -演示

0、引言 在开始本文之前&#xff0c;推荐您首先阅读 Apache log4net™ 手册中有关 介绍 与 配置 的相关内容。本文将通过实践分别为您演示如何使用 Visual Studio 2022 在 .NET Framework 项目和 .NET 项目下配置并使用 Log4Net。 1、为 .NET Framework 项目配置 Log4Net 1.1…...

VScode远程root权限调试

尝试诸多办法无法解决的情况下&#xff0c;允许远程登陆用户直接以root身份登录 编辑sshd_config文件 sudo vim /etc/ssh/sshd_config 激活配置 注释掉PermitRootLogin without-password&#xff0c;即#PermitRootLogin without-password 增加一行&#xff1a;PermitRootLo…...

【ARM CoreLink 系列 7 -- TZC-400控制器简介】

文章目录 背景介绍1.1 TZC-400 简介1.2 TZC-400 使用示例1.3 TZC-400 interfaces1.3.1 FPID1.3.2 NSAID Regionregion 检查规则 1.4 Features1.5 Register summary1.6 TZC-400和TZPC和TZASC区别 背景介绍 为了确保内存能够正确识别总线的信号控制位&#xff0c;新增一个TrustZ…...

【C++】-c++11的知识点(中)--lambda表达式,可变模板参数以及包装类(bind绑定)

&#x1f496;作者&#xff1a;小树苗渴望变成参天大树&#x1f388; &#x1f389;作者宣言&#xff1a;认真写好每一篇博客&#x1f4a4; &#x1f38a;作者gitee:gitee✨ &#x1f49e;作者专栏&#xff1a;C语言,数据结构初阶,Linux,C 动态规划算法&#x1f384; 如 果 你 …...

浅析倾斜摄影三维模型(3D)几何坐标精度偏差的几个因素

浅析倾斜摄影三维模型&#xff08;3D&#xff09;几何坐标精度偏差的几个因素 倾斜摄影是一种通过倾斜角度较大的相机拍摄建筑物、地形等场景&#xff0c;从而生成高精度的三维模型的技术。然而&#xff0c;在进行倾斜摄影操作时&#xff0c;由于多种因素的影响&#xff0c;导致…...

【广州华锐互动】智轨列车AR互动教学系统

智轨列车&#xff0c;也被称为路面电车或拖电车&#xff0c;是一种公共交通工具&#xff0c;它在城市的街头巷尾提供了一种有效、环保的出行方式。智轨列车的概念已经存在了很长时间&#xff0c;但是随着科技的发展&#xff0c;我们现在可以更好地理解和欣赏它。通过使用增强现…...

驾驶数字未来:汽车业界数字孪生技术的崭新前景

随着数字化时代的到来&#xff0c;汽车行业正经历着前所未有的变革。数字孪生技术&#xff0c;作为一种前沿的数字化工具&#xff0c;正在为汽车行业带来革命性的影响&#xff0c;不仅改变着汽车制造和维护的方式&#xff0c;也为消费者带来了前所未有的体验。让我们一起探讨&a…...

JVM 性能调优参数

JVM分为堆内存和非堆内存 堆的内存分配用-Xms和-Xmx -Xms分配堆最小内存&#xff0c;默认为物理内存的1/64&#xff1b; -Xmx分配最大内存&#xff0c;默认为物理内存的1/4。 非堆内存分配用-XX:PermSize和-XX:MaxPermSize -XX:PermSize分配非堆最小内存&#xff0c;默认为物理…...

11在SpringMVC中响应到浏览器的数据格式,@ResponseBody注解和@RestController复合注解的功能详解

响应数据/转发或重定向页面 参考文章数据交换的常见格式,如JSON格式和XML格式 服务器将接收到请求处理完以后需要将处理结果告知给浏览器即响应,通常有响应要转发/重定向到的页面和响应数据(文本数据/json数据)两种方式 如果控制器方法返回值类型为void并且没有通过response…...

go 流程控制之switch 语句介绍

go 流程控制之switch 语句介绍 文章目录 go 流程控制之switch 语句介绍一、switch语句介绍1.1 认识 switch 语句1.2 基本语法 二、Go语言switch语句中case表达式求值顺序2.1 switch语句中case表达式求值次序介绍2.2 switch语句中case表达式的求值次序特点 三、switch 语句的灵活…...

sql 时间有偏差的解决方法

测试功能的时候发现记录的创建时间不对&#xff0c;死活对不上&#xff0c;下意识的以为是服务器时间有偏差&#xff0c;后来排查发现存入表中的时间是正常的&#xff0c;但是查询展示出来的时间是不对的&#xff0c;就去排查可能是查询sql格式化时间有问题&#xff0c;果不其然…...

Apache Lucene 7.0 - 索引文件格式

Apache Lucene 7.0 - 索引文件格式 文章目录 Apache Lucene 7.0 - 索引文件格式介绍定义反向索引字段类型段文档数量索引结构概述文件命名文件扩展名摘要锁文件 原文地址 介绍 这个文档定义了在这个版本的Lucene中使用的索引文件格式。如果您使用的是不同版本的Lucene&#xf…...

云计算——弹性云计算器(ECS)

弹性云服务器&#xff1a;ECS 概述 云计算重构了ICT系统&#xff0c;云计算平台厂商推出使得厂家能够主要关注应用管理而非平台管理的云平台&#xff0c;包含如下主要概念。 ECS&#xff08;Elastic Cloud Server&#xff09;&#xff1a;即弹性云服务器&#xff0c;是云计算…...

SciencePlots——绘制论文中的图片

文章目录 安装一、风格二、1 资源 安装 # 安装最新版 pip install githttps://github.com/garrettj403/SciencePlots.git# 安装稳定版 pip install SciencePlots一、风格 简单好用的深度学习论文绘图专用工具包–Science Plot 二、 1 资源 论文绘图神器来了&#xff1a;一行…...

从深圳崛起的“机器之眼”:赴港乐动机器人的万亿赛道赶考路

进入2025年以来&#xff0c;尽管围绕人形机器人、具身智能等机器人赛道的质疑声不断&#xff0c;但全球市场热度依然高涨&#xff0c;入局者持续增加。 以国内市场为例&#xff0c;天眼查专业版数据显示&#xff0c;截至5月底&#xff0c;我国现存在业、存续状态的机器人相关企…...

抖音增长新引擎:品融电商,一站式全案代运营领跑者

抖音增长新引擎&#xff1a;品融电商&#xff0c;一站式全案代运营领跑者 在抖音这个日活超7亿的流量汪洋中&#xff0c;品牌如何破浪前行&#xff1f;自建团队成本高、效果难控&#xff1b;碎片化运营又难成合力——这正是许多企业面临的增长困局。品融电商以「抖音全案代运营…...

分布式增量爬虫实现方案

之前我们在讨论的是分布式爬虫如何实现增量爬取。增量爬虫的目标是只爬取新产生或发生变化的页面&#xff0c;避免重复抓取&#xff0c;以节省资源和时间。 在分布式环境下&#xff0c;增量爬虫的实现需要考虑多个爬虫节点之间的协调和去重。 另一种思路&#xff1a;将增量判…...

基于matlab策略迭代和值迭代法的动态规划

经典的基于策略迭代和值迭代法的动态规划matlab代码&#xff0c;实现机器人的最优运输 Dynamic-Programming-master/Environment.pdf , 104724 Dynamic-Programming-master/README.md , 506 Dynamic-Programming-master/generalizedPolicyIteration.m , 1970 Dynamic-Programm…...

均衡后的SNRSINR

本文主要摘自参考文献中的前两篇&#xff0c;相关文献中经常会出现MIMO检测后的SINR不过一直没有找到相关数学推到过程&#xff0c;其中文献[1]中给出了相关原理在此仅做记录。 1. 系统模型 复信道模型 n t n_t nt​ 根发送天线&#xff0c; n r n_r nr​ 根接收天线的 MIMO 系…...

Reasoning over Uncertain Text by Generative Large Language Models

https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829 1. 概述 文本中的不确定性在许多语境中传达,从日常对话到特定领域的文档(例如医学文档)(Heritage 2013;Landmark、Gulbrandsen 和 Svenevei…...

在Mathematica中实现Newton-Raphson迭代的收敛时间算法(一般三次多项式)

考察一般的三次多项式&#xff0c;以r为参数&#xff1a; p[z_, r_] : z^3 (r - 1) z - r; roots[r_] : z /. Solve[p[z, r] 0, z]&#xff1b; 此多项式的根为&#xff1a; 尽管看起来这个多项式是特殊的&#xff0c;其实一般的三次多项式都是可以通过线性变换化为这个形式…...

【JVM】Java虚拟机(二)——垃圾回收

目录 一、如何判断对象可以回收 &#xff08;一&#xff09;引用计数法 &#xff08;二&#xff09;可达性分析算法 二、垃圾回收算法 &#xff08;一&#xff09;标记清除 &#xff08;二&#xff09;标记整理 &#xff08;三&#xff09;复制 &#xff08;四&#xff…...