文件IO

1:思维导图

2:使用3语言编写一个简易的界面,界面如下 1:标准输出流 2:标准错误流 3:文件流 要求:按1的时候,通过printf输出数据,按2的时候,通过perror输出数据,按3的时候将输入写入文件中 同时通过dup2函数,将标准错误流重定向到错误日志,将文件流重定向到终端

cs 复制代码
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <unistd.h>
#include <fcntl.h>
int main(int argc, const char *argv[])
{
	printf("1.标准输出流\n");
	printf("2.标准错误流\n");
	printf("3.文件流\n");
	int err = open("err.txt",O_RDWR|O_CREAT|O_TRUNC,0666);
	int file = open("file.txt",O_WRONLY|O_CREAT|O_TRUNC,0666);
	char arr[10]="hello\n";
	int num;
	while(1)
	{
		printf("请输入操作:");
		scanf("%d",&num);
		switch(num)
		{
			case 1:
				printf("标准输出流\n");
				break;
			case 2:
				perror("标准错误流\n");
				break;
			case 3:
				write(file,arr,sizeof(arr));
				dup2(err,2);
				dup2(0,file);
				break;
			default:
				return 0;

		}
	}
	close(err);
	close(file);

	return 0;
}

3:使用stat函数判断一个文件是否存在 同组人可执行 权限,如果存在则去除该权限,如果不存在则追加该权限 自己想办法查询 更改文件权限的函数是什么

cs 复制代码
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <unistd.h>
#include <fcntl.h>
int main(int argc, const char *argv[])
{
	printf("1.标准输出流\n");
	printf("2.标准错误流\n");
	printf("3.文件流\n");
	int err = open("err.txt",O_RDWR|O_CREAT|O_TRUNC,0666);
	int file = open("file.txt",O_WRONLY|O_CREAT|O_TRUNC,0666);
	char arr[10]="hello\n";
	int num;
	while(1)
	{
		printf("请输入操作:");
		scanf("%d",&num);
		switch(num)
		{
			case 1:
				printf("标准输出流\n");
				break;
			case 2:
				perror("标准错误流\n");
				break;
			case 3:
				write(file,arr,sizeof(arr));
				dup2(err,2);
				dup2(0,file);
				break;
			default:
				return 0;

		}
	}
	close(err);
	close(file);

	return 0;
}
相关推荐
前端付豪2 小时前
微信视频号推荐系统揭秘:兴趣建模、多模态分析与亿级流控架构实战
前端·后端·算法
木杉苑2 小时前
快速幂算法
算法
-qOVOp-5 小时前
408第一季 - 数据结构 - 排序II
数据结构·算法·排序算法
小胖同学~5 小时前
快速入门数据结构--栈
算法
C++ 老炮儿的技术栈5 小时前
VSCode -配置为中文界面
大数据·c语言·c++·ide·vscode·算法·编辑器
刃神太酷啦5 小时前
聚焦 string:C++ 文本处理的核心利器--《Hello C++ Wrold!》(10)--(C/C++)
java·c语言·c++·qt·算法·leetcode·github
CoovallyAIHub5 小时前
云南电网实战:YOLOv8m改进模型攻克输电线路异物检测难题技术详解
深度学习·算法·计算机视觉
蜗牛的旷野5 小时前
华为OD机试_2025 B卷_磁盘容量排序(Python,100分)(附详细解题思路)
python·算法·华为od
Sun_light5 小时前
链表 --- 高效离散存储的线性数据结构
前端·javascript·算法
西西弗Sisyphus5 小时前
低秩分解的本质是通过基矩阵和系数矩阵的线性组合,以最小的存储和计算代价近似表示复杂矩阵
线性代数·算法·矩阵