实现一个函数,可以删除文件的[n,m)个字节

        实现此函数的基本思路:先提取 n 以前的数据段存入缓冲区,再提取 m 以后的数据段存入缓冲区,然后把缓冲区中的数据段重新写入文件,最后用 truncate 函数来截断文件。

需要注意的是,这里给的区间是一个左闭右开的区间,因此在文件内移动指针的时候要作相应处理,以完成删除 n 但不删除 m。

#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>

int cut_file(const char *path,size_t n,size_t m)
{
    if(n<0||m<n) return -1;
    FILE *fp=fopen(path,"r+");
    if(NULL==fp)
    {
        perror("fopen");
        return -1;
    }

    char *first=malloc(n-1);
    fread(first,1,n-1,fp);//把fp所指文件的n-1个字节存入缓冲区,前一段数据
    if(!first)
    {   
        perror("fread");
        return -1; 
    }   

    fseek(fp,m-1,SEEK_SET);//因为左闭右开,所以把指针-1拿到缓冲区

    struct stat statbuf;
    stat(path,&statbuf);//获取文件属性
    int range=statbuf.st_size-m;//存放后面一段数据的范围
    
    char *second=malloc(range);
    fread(second,1,range,fp);//存放后一段数据
    if(!second)
    {
        perror("fread");
        return -1;
    }
    //从头开始写入
    rewind(fp);//把指针移到文件头部准备写入工作
    fwrite(first,1,n-1,fp);//先写入前一段数据
    fwrite(second,1,range,fp);//再写入后一段数据
    truncate(path,n-1+range);//把文件截断

    free(first);
    free(second);
    fclose(fp);
    return 0;
}

int main(int argc,const char* argv[])
{
    int n=2,m=4;//要删除的区间,为左闭右开,第2个要删除,第4个不删除
    if(!cut_file("test.txt",n,m)) printf("cut success!");
    else printf("cut fail");

    return 0;
}

over

明白了!下面是将两个函数 **`worker_file_log_set_handle`** 和 **`tpsocket_event_filelog_to_hub`** 分别单独绘制为两个 Mermaid 流程图,每个函数一个完整的流程图代码,便于你分别使用或展示。 --- ### ✅ 函数一:`worker_file_log_set_handle` 的 Mermaid 流程图 ```mermaid graph TD A[开始 worker_file_log_set_handle] --> B[从 buf 中提取 Device-Mac] B --> C{MAC 是否有效?} C -- 否 --> D[返回 false, MAC 无效] C -- 是 --> E[格式化 MAC 地址 (冒号替换为下划线)] E --> F[构建目标目录路径 /mnt/sd_card/<processed_mac>] F --> G{目录是否存在?} G -- 否 --> H[创建目录] G -- 是 --> I[继续] H --> I I --> J[构建文件路径 log.txt] J --> K[获取 Content-Length] K --> L{Content-Length 是否有效?} L -- 否 --> M[返回 false, 内容长度无效] L -- 是 --> N[打开文件 log.txt 以追加模式] N --> O[获取文件大小] O --> P{内容长度 + 文件大小是否超过最大限制?} P -- 是 --> Q[循环删除旧日志行直到空间足够] Q --> R[处理大文件截断] R --> S[更新文件大小] P -- 否 --> S S --> T[分配 FileLogSession 结构] T --> U{分配是否成功?} U -- 否 --> V[返回 false] U -- 是 --> W[设置 session->fp = 文件指针] W --> X[设置 session->remaining = content_len] X --> Y[检查 X-If-Encrypt 请求头] Y --> Z{是否为 1?} Z -- 是 --> AA[设置 session->decrypt_flag = 1] Z -- 否 --> AB[设置 session->decrypt_flag = 0] AA --> AC[获取并设置 nonce] AC --> AD[调用 work_tapo_log_refresh_nonce] AB --> AE[设置 session->filepath] AE --> AF[设置 sock->handler 回调函数为 tpsocket_event_filelog_to_hub] AF --> AG[返回 true,设置成功] ``` --- ### ✅ 函数二:`tpsocket_event_filelog_to_hub` 的 Mermaid 流程图 ```mermaid graph TD AH[进入 tpsocket_event_filelog_to_hub] --> AI{event 类型} AI -- TPSOCKET_EVENT_REQ_HEAD --> AJ[处理请求头] AJ --> AK[释放旧 session] AK --> AL[提取 Device-Mac] AL --> AM{MAC 是否有效?} AM -- 否 --> AN[返回错误] AM -- 是 --> AO[格式化 MAC] AO --> AP[构建目录路径] AP --> AQ[创建目录] AQ --> AR[打开 log.txt 文件] AR --> AS[获取 Content-Length] AS --> AT[创建 session 并保存参数] AT --> AU[设置 handler->priv = session] AU --> AV[结束处理] AI -- TPSOCKET_EVENT_MESSAGE --> AW[处理数据消息] AW --> AX[合并 buffer] AX --> AY{fp 是否为空?} AY -- 是 --> AZ[返回错误] AY -- 否 --> BA[提取 request 字段] BA --> BB{是否成功提取?} BB -- 是 --> BC[更新 input_data 和 input_len] BB -- 否 --> BD[input_data 保持原样] BD --> BE{decrypt_flag 是否为 1?} BE -- 是 --> BF[修复 Base64 字符串] BF --> BG[Base64 解码] BG --> BH[解密数据] BH --> BI{解密是否成功?} BI -- 是 --> BJ[写入解密后的内容到文件] BI -- 否 --> BK[写入原始内容到文件] BE -- 否 --> BK BK --> BL[更新 remaining 字节数] BL --> BM{是否传输完成或出错?} BM -- 是 --> BN[关闭文件] BN --> BO{是否出错?} BO -- 是 --> BP[发送 HTTP 500 错误响应] BO -- 否 --> BQ[发送 HTTP 200 OK 响应] BP --> BR[释放 session] BQ --> BR BR --> BS[结束处理] AI -- TPSOCKET_EVENT_CLOSED --> BT[清理 session 和文件] BT --> BU[删除文件] BU --> BV[释放 session] BV --> BW[结束处理] ``` --- ### 📌 使用说明 - 每个函数一个独立的 Mermaid 流程图; - 可分别粘贴到 [Mermaid Live Editor](https://mermaid.live/) 中查看; - 支持导出为 PNG、SVG、PDF; - 可用于文档、代码说明、流程分析等场景。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值