【Linux】设计文件系统(C实现)

要求:

        (1)可以实现下列几条命令 

                dir     列文件目录
                create  创建文件
                delete  删除文件
                read    读文件        
                write   写文件

        (2)列目录时要列出文件名、存取权限(八进制)、文件长度、时间(创建时间,修改时间以及最后一次访问时间);

        (3)源文件可以进行读写保护。

代码:

定义结构体

typedef struct {char name[MAX_NAME_LEN];//最大文件数int permission;//权限int size;//大小  char content[MAX_CONTENT_LEN];//内容char create_time[20];  //创建时间char modify_time[20];  //修改时间char access_time[20];  //最后一次访问时间
} File;

获取当前时间(在显示创建时间,修改时间和访问时间时使用,用于记录当前时间)

//获取当前时间
void get_current_time(char *buffer) {time_t now = time(NULL);struct tm *t = localtime(&now);strftime(buffer, 20, "%Y-%m-%d %H:%M:%S", t);
}

创建文件(创建时注意要赋权)

void create_file() {if (file_count >= MAX_FILES) {printf("文件数量已达上限,无法创建新文件。\n");return;}char name[MAX_NAME_LEN];int permission;printf("请输入文件名: ");scanf("%s", name);printf("请输入文件权限(八进制): ");scanf("%o", &permission);for (int i = 0; i < file_count; i++) {if (strcmp(file_system[i].name, name) == 0) {printf("文件已存在。\n");return;}}File new_file;strcpy(new_file.name, name);new_file.permission = permission;new_file.size = 0;new_file.content[0] = '\0';get_current_time(new_file.create_time);strcpy(new_file.modify_time, new_file.create_time);strcpy(new_file.access_time, new_file.create_time); file_system[file_count++] = new_file;printf("文件创建成功。\n");
}

删除文件

void create_file() {if (file_count >= MAX_FILES) {printf("文件数量已达上限,无法创建新文件。\n");return;}char name[MAX_NAME_LEN];int permission;printf("请输入文件名: ");scanf("%s", name);printf("请输入文件权限(八进制): ");scanf("%o", &permission);for (int i = 0; i < file_count; i++) {if (strcmp(file_system[i].name, name) == 0) {printf("文件已存在。\n");return;}}File new_file;strcpy(new_file.name, name);new_file.permission = permission;new_file.size = 0;new_file.content[0] = '\0';get_current_time(new_file.create_time);strcpy(new_file.modify_time, new_file.create_time);strcpy(new_file.access_time, new_file.create_time); file_system[file_count++] = new_file;printf("文件创建成功。\n");
}

读文件

void read_file() {char name[MAX_NAME_LEN];printf("请输入要读取的文件名: ");scanf("%s", name);for (int i = 0; i < file_count; i++) {if (strcmp(file_system[i].name, name) == 0) {printf("文件内容:\n%s\n", file_system[i].content);get_current_time(file_system[i].access_time);  return;}}printf("文件未找到。\n");
}

写文件

void write_file() {char name[MAX_NAME_LEN];char content[MAX_CONTENT_LEN];printf("请输入要写入的文件名: ");scanf("%s", name);for (int i = 0; i < file_count; i++) {if (strcmp(file_system[i].name, name) == 0) {printf("请输入文件内容: ");getchar(); fgets(content, MAX_CONTENT_LEN, stdin);content[strcspn(content, "\n")] = '\0'; strcpy(file_system[i].content, content);file_system[i].size = strlen(content);get_current_time(file_system[i].modify_time);printf("文件写入成功。\n");return;}}printf("文件未找到。\n");
}

列出文件

void list_files() {if (file_count == 0) {printf("目录为空。\n");return;}printf("%-20s %-10s %-10s %-20s %-20s %-20s\n","文件名", "权限", "大小", "创建时间", "修改时间", "访问时间");for (int i = 0; i < file_count; i++) {printf("%-20s %-10o %-10d %-20s %-20s %-20s\n",file_system[i].name,file_system[i].permission,file_system[i].size,file_system[i].create_time,file_system[i].modify_time,file_system[i].access_time);}
}

目录

void menu() {printf("\n==== 文件系统 ====\n");printf("1. 列文件目录\n");printf("2. 创建文件\n");printf("3. 删除文件\n");printf("4. 读文件\n");printf("5. 写文件\n");printf("6. 退出\n");printf("===================\n");
}

main

int main() {int choice;while (1) {menu();printf("请输入选项: ");scanf("%d", &choice);switch (choice) {case 1:list_files();break;case 2:create_file();break;case 3:delete_file();break;case 4:read_file();break;case 5:write_file();break;case 6:printf("退出系统。\n");return 0;default:printf("无效选项,请重新输入。\n");}}
}

各个部分的代码都已分别给出,可自行在此程序上加入自己的逻辑。

完整代码

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <time.h>#define MAX_FILES 100     //最大文件数
#define MAX_NAME_LEN 50   //文件名字最大长度
#define MAX_CONTENT_LEN 1024 //文件最大内容typedef struct {char name[MAX_NAME_LEN];//最大文件数int permission;//权限int size;//大小  char content[MAX_CONTENT_LEN];//内容char create_time[20];  //创建时间char modify_time[20];  //修改时间char access_time[20];  //最后一次访问时间
} File;File file_system[MAX_FILES];
int file_count = 0;//获取当前时间
void get_current_time(char *buffer) {time_t now = time(NULL);struct tm *t = localtime(&now);strftime(buffer, 20, "%Y-%m-%d %H:%M:%S", t);
}//创建文件
void create_file() {if (file_count >= MAX_FILES) {printf("文件数量已达上限,无法创建新文件。\n");return;}char name[MAX_NAME_LEN];int permission;printf("请输入文件名: ");scanf("%s", name);printf("请输入文件权限(八进制): ");scanf("%o", &permission);for (int i = 0; i < file_count; i++) {if (strcmp(file_system[i].name, name) == 0) {printf("文件已存在。\n");return;}}File new_file;strcpy(new_file.name, name);new_file.permission = permission;new_file.size = 0;new_file.content[0] = '\0';get_current_time(new_file.create_time);strcpy(new_file.modify_time, new_file.create_time);strcpy(new_file.access_time, new_file.create_time); file_system[file_count++] = new_file;printf("文件创建成功。\n");
}//删除文件
void delete_file() {char name[MAX_NAME_LEN];printf("请输入要删除的文件名: ");scanf("%s", name);for (int i = 0; i < file_count; i++) {if (strcmp(file_system[i].name, name) == 0) {for (int j = i; j < file_count - 1; j++) {file_system[j] = file_system[j + 1];}file_count--;printf("文件删除成功。\n");return;}}printf("文件未找到。\n");
}//读文件
void read_file() {char name[MAX_NAME_LEN];printf("请输入要读取的文件名: ");scanf("%s", name);for (int i = 0; i < file_count; i++) {if (strcmp(file_system[i].name, name) == 0) {printf("文件内容:\n%s\n", file_system[i].content);get_current_time(file_system[i].access_time);  return;}}printf("文件未找到。\n");
}//写文件
void write_file() {char name[MAX_NAME_LEN];char content[MAX_CONTENT_LEN];printf("请输入要写入的文件名: ");scanf("%s", name);for (int i = 0; i < file_count; i++) {if (strcmp(file_system[i].name, name) == 0) {printf("请输入文件内容: ");getchar(); fgets(content, MAX_CONTENT_LEN, stdin);content[strcspn(content, "\n")] = '\0'; strcpy(file_system[i].content, content);file_system[i].size = strlen(content);get_current_time(file_system[i].modify_time);printf("文件写入成功。\n");return;}}printf("文件未找到。\n");
}//列出文件
void list_files() {if (file_count == 0) {printf("目录为空。\n");return;}printf("%-20s %-10s %-10s %-20s %-20s %-20s\n","文件名", "权限", "大小", "创建时间", "修改时间", "访问时间");for (int i = 0; i < file_count; i++) {printf("%-20s %-10o %-10d %-20s %-20s %-20s\n",file_system[i].name,file_system[i].permission,file_system[i].size,file_system[i].create_time,file_system[i].modify_time,file_system[i].access_time);}
}//目录
void menu() {printf("\n==== 文件系统 ====\n");printf("1. 列文件目录\n");printf("2. 创建文件\n");printf("3. 删除文件\n");printf("4. 读文件\n");printf("5. 写文件\n");printf("6. 退出\n");printf("===================\n");
}int main() {int choice;while (1) {menu();printf("请输入选项: ");scanf("%d", &choice);switch (choice) {case 1:list_files();break;case 2:create_file();break;case 3:delete_file();break;case 4:read_file();break;case 5:write_file();break;case 6:printf("退出系统。\n");return 0;default:printf("无效选项,请重新输入。\n");}}
}

运行结果(在虚拟机上运行)

1).创建文件

2).列出文件

3).写文件

4).读文件

5).删除文件

6).删除文件

小结:

        首先注意此代码在linux中编译时可能会报错如下:

因为我的代码中使用了 C99 标准引入的特性——for 循环中声明变量。然而,编译器默认未启用 C99 模式,因此报错。 

解决方法:在编译时指定用c99模式,因为 C99 是现代 C 标准,支持更多特性,所以我没有考虑将代码切换兼容 C89。

列表显示时对齐问题,占位符有讲究(为了尽量得体的显示)(给出的代码的占位符都是设计的尽量显示正常的)

开始时时间都无法在同一行显示,显然有问题

那么代码就能正常运行啦,但是因为博主技术水平问题,只能写出这样的代码供大家参考。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/62919.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

开源用户体验调查管理平台Formbricks

什么是 Formbricks &#xff1f; Formbricks 是一个开源的调查和体验管理平台&#xff0c;旨在帮助用户在应用内、网站、链接和电子邮件中收集用户和客户的反馈。它为开发者提供了一个隐私优先的替代方案&#xff0c;支持自托管或使用 Formbricks 云服务&#xff0c;并提供了丰…

0.Git初步概念

1.Git应用场景 场景一&#xff1a;资料备份 场景二&#xff1a;代码还原(回滚) 场景三&#xff1a;协同开发 场景四&#xff1a;追溯问题代码的开发人和开发时间 解决方式&#xff1a;版本控制 2.版本控制方式 a、集中式版本控制工具 用户将代码集中存储到中央服务器&#x…

040集——CAD中放烟花(CAD—C#二次开发入门)

效果如下&#xff1a; 单一颜色的烟花&#xff1a; 渐变色的火花&#xff1a; namespace AcTools {public class HH{public static TransientManager tm TransientManager.CurrentTransientManager;public static Random rand new Random();public static Vector3D G new V…

自然语言处理:基于BERT预训练模型的中文命名实体识别(使用PyTorch)

命名实体识别&#xff08;NER&#xff09; 命名实体识别&#xff08;Named Entity Recognition, NER&#xff09;是自然语言处理&#xff08;NLP&#xff09;中的一个关键任务&#xff0c;其目标是从文本中识别出具有特定意义的实体&#xff0c;并将其分类到预定义的类别中。这…

Pytorch实现心跳信号分类识别(支持LSTM,GRU,TCN模型)

Pytorch实现心跳信号分类识别(支持LSTM,GRU,TCN模型&#xff09; 目录 Pytorch实现心跳信号分类识别(支持LSTM,GRU,TCN模型&#xff09; 1. 项目说明 2. 数据说明 &#xff08;1&#xff09;心跳信号分类预测数据集 3. 模型训练 &#xff08;1&#xff09;项目安装 &…

十,[极客大挑战 2019]Secret File1

点击进入靶场 查看源代码 有个显眼的紫色文件夹&#xff0c;点击 点击secret看看 既然这样&#xff0c;那就回去查看源代码吧 好像没什么用 抓个包 得到一个文件名 404 如果包含"../"、"tp"、"input"或"data"&#xff0c;则输出"…

视觉处理基础1

目录 一、CNN 1. 概述 1.1 与传统网络的区别 1.2 全连接的局限性 1.3 卷积思想 1.4 卷积的概念 1.4.1 概念 1.4.2 局部连接 1.4.3 权重共享 2. 卷积层 2.1 卷积核 2.2 卷积计算 2.3 边缘填充 2.4 步长Stride 2.5 多通道卷积计算 2.7 特征图大小计算方法 2…

泛化调用 :在没有接口的情况下进行RPC调用

什么是泛化调用&#xff1f; 在RPC调用的过程中&#xff0c;调用端向服务端发起请求&#xff0c;首先要通过动态代理&#xff0c;动态代理可以屏蔽RPC处理流程&#xff0c;使得发起远程调用就像调用本地一样。 RPC调用本质&#xff1a;调用端向服务端发送一条请求消息&#x…

C++ 之弦上舞:string 类与多样字符串操作的优雅旋律

string 类的重要性及与 C 语言字符串对比 在 C 语言中&#xff0c;字符串是以 \0 结尾的字符集合&#xff0c;操作字符串需借助 C 标准库的 str 系列函数&#xff0c;但这些函数与字符串分离&#xff0c;不符合 OOP 思想&#xff0c;且底层空间管理易出错。而在 C 中&#xff0…

【大数据学习 | Spark调优篇】Spark之内存调优

1. 内存的花费 1&#xff09;每个Java对象&#xff0c;都有一个对象头&#xff0c;会占用16个字节&#xff0c;主要是包括了一些对象的元信息&#xff0c;比如指向它的类的指针。如果一个对象本身很小&#xff0c;比如就包括了一个int类型的field&#xff0c;那么它的对象头实…

【closerAI ComfyUI】物体转移术之图案转移,Flux三重控制万物一致性生图,实现LOGO和图案的精准迁移

更多AI前沿科技资讯,请关注我们:closerAI-一个深入探索前沿人工智能与AIGC领域的资讯平台 closerAIGCcloserAI,一个深入探索前沿人工智能与AIGC领域的资讯平台,我们旨在让AIGC渗入我们的工作与生活中,让我们一起探索AIGC的无限可能性! 【closerAI ComfyUI】物体转移术之图…

2025软考高级《系统架构设计师》案例模拟题合集

首先分享一下系统架构设计师资料合集&#xff0c;有历年真题、自学打卡表、精华知识点等&#xff0c;需要的留邮&#xff0c;打包分享&#xff01; 1、在设计基于混合云的安全生产管理系统中&#xff0c;需要重点考虑5个方面的安全问题。设备安全、网络安全、控制安全、应用安全…

【C语言】递归的内存占用过程

递归 递归是函数调用自身的一种编程技术。在C语言中&#xff0c;递归的实现会占用内存栈&#xff08;Call Stack&#xff09;&#xff0c;每次递归调用都会在栈上分配一个新的 “栈帧&#xff08;Stack Frame&#xff09;”&#xff0c;用于存储本次调用的函数局部变量、返回地…

LeetCode 438.找到字符串中所有字母异位词

LeetCode 438.找到字符串中所有字母异位词 思路&#x1f9d0;&#xff1a; 需要找到子串异位词&#xff0c;也就是只看该子串是否有相同字母而不管位置是否相同。分析题目发现只需要单调向前找异位词&#xff0c;则可以使用滑动窗口求解&#xff0c;注意这里每当左右边框长度大…

算法刷题Day8:BM30 二叉搜索树与双向链表

题目 牛客网题目传送门 思路 对二叉搜索树进行中序遍历&#xff0c;结果就是按序数组。因此想办法把前面遍历过的节点给记下来&#xff0c;记作pre。当遍历到某个节点node的时候&#xff0c;令前驱指向pre&#xff0c;然后让pre的后驱指向node。 代码 class TreeNode:def…

1.Git安装与常用命令

前言 Git中会用到的一些基本的Linux命令 ls/ll 查看文件目录 (ll可以看隐藏文件)cat 查看文件内容touch 创建文件vi vi编辑器 1.下载与安装 安装成功后鼠标右键会出现Git Bash和Git GUI Git GUI&#xff1a;GUI图形化界面 Git Bash&#xff1a;Git提供的命令行工具 当安装…

ultralytics-YOLOv11的目标检测解析

1. Python的调用 from ultralytics import YOLO import os def detect_predict():model YOLO(../weights/yolo11n.pt)print(model)results model(../ultralytics/assets/bus.jpg)if not os.path.exists(results[0].save_dir):os.makedirs(results[0].save_dir)for result in…

【AI系统】CANN 算子类型

CANN 算子类型 算子是编程和数学中的重要概念&#xff0c;它们是用于执行特定操作的符号或函数&#xff0c;以便处理输入值并生成输出值。本文将会介绍 CANN 算子类型及其在 AI 编程和神经网络中的应用&#xff0c;以及华为 CANN 算子在 AI CPU 的详细架构和开发要求。 算子基…

服务器与普通电脑有什么区别?

服务器和普通电脑&#xff08;通常指的是个人计算机&#xff0c;即PC&#xff09;有众多相似之处&#xff0c;主要构成包含&#xff1a;CPU&#xff0c;内存&#xff0c;芯片&#xff0c;I/O总线设备&#xff0c;电源&#xff0c;机箱及操作系统软件等&#xff0c;鉴于使用要求…

hhdb数据库介绍(10-33)

管理 数据归档 归档记录查询 功能入口&#xff1a;“管理->数据归档->归档记录查询” 需要确保配置的归档用户对数据归档规则所在的逻辑库具备CREATE权限&#xff0c;以及对原数据表具有所有权限。 清理归档数据 &#xff08;一&#xff09;功能入口&#xff1a;“…