《C 语言字符串操作从入门到实战(下篇):strncpy/strncat/strstr 等函数原理与实现》

news2025/6/7 21:55:53

目录

七. strncpy函数的使用与模拟实现

7.1  strncpy函数理解

7.2  strncpy函数使用示例

7.3  strncpy函数模拟实现

八. strncat函数的使用与模拟实现

8.1 strncat函数理解

8.2 strncat函数使用示例

8.3 strncat函数模拟实现

九. strncmp函数的使用

9.1 strncmp函数理解

9.2 strncmp函数使用示例

十. strstr函数的使用与模拟实现

10.1 strstr函数理解

10.2 strstr函数使用示例

10.3 strstr函数模拟实现

十一. strtok函数的使用与模拟实现

11.1 strtok函数理解

11.2 strtok函数使用示例

11.3 strtok注意事项

十二. strerror函数的使用与模拟实现

12.1 strerror函数理解

12.2 strerror函数使用

12.3 perror函数


七. strncpy函数的使用与模拟实现

7.1  strncpy函数理解

strncpy 是 C 标准库中用于复制字符串的函数,定义在 <string.h> 头文件中。相比 strcpy,它提供了长度限制,可以防止缓冲区溢出。

函数原型

char *strncpy(char *dest, const char *src, size_t n);

参数说明

  • dest: 目标字符数组,用于存储复制的内容

  • src: 源字符串,将被复制的字符串

  • n: 最多复制的字符数(包括 ‘\0’)

返回值

返回目标字符串 dest 的指针

功能特点

  1. 复制最多 n 个字符 从 src 到 dest

  2. 两种终止条件:

    • 遇到 src 的 ‘\0’ 终止符

    • 达到最大字符数 n

7.2  strncpy函数使用示例

#include<stdio.h>
#include<string.h>
int main()
{
	char arr1[20] = { 0 };
	char arr2[] = "hello,worldCCCCCCC";
	char* p = strncpy(arr1, arr2, 11);
	printf("%s\n", p);
	printf("%s\n", arr1);
	return 0;
}

7.3  strncpy函数模拟实现

#include<stdio.h>   // 标准输入输出库
#include<string.h>  // 字符串操作库
#include<assert.h>  // 断言库

// 自定义的strncpy函数
// 参数:arr1 - 目标字符串,arr2 - 源字符串,num - 要拷贝的字符数
// 返回值:指向目标字符串的指针
char* my_strncpy(char* arr1, const char* arr2, size_t num)
{
    // 使用断言确保目标指针和源指针都不为NULL
    assert(arr1 && arr2);
    
    // 保存目标字符串的起始地址,用于返回
    char* p = arr1;
    int i = 0;
    
    // 循环拷贝字符,直到达到指定数量或遇到源字符串的结束符
    for (i = 0; i < num && arr2[i]; i++)
    {
        arr1[i] = arr2[i];
    }
    
    // 如果拷贝的字符数少于指定数量,则在目标字符串后添加结束符
    if (i < num)
    {
        arr1[i] = 0;
    }
    
    // 返回目标字符串的起始地址
    return p;
}

int main()
{
    char arr1[20] = { 0 };        // 初始化目标字符串数组,全部置为0
    char arr2[] = "abcdefg";      // 源字符串
    char* ret = my_strncpy(arr1, arr2, 5);  // 调用自定义函数,拷贝前5个字符
    
    printf("%s", ret);            // 输出结果:abcde
    return 0;
}

八. strncat函数的使用与模拟实现

8.1strncat函数理解

strncat 是 C 标准库中的一个字符串拼接函数,用于将源字符串的前 n 个字符追加到目标字符串的末尾,并自动添加终止符 \0

函数原型

char *strncat(char *dest, const char *src, size_t n);
  • dest:目标字符串(必须足够大以容纳追加后的结果)。
  • src:源字符串(不会被修改)。
  • n:最多追加的字符数(如果 src 长度小于 n,则只追加 src 的全部内容)。
  • 返回值:返回 dest 的指针。

8.2 strncat函数使用示例

#include<stdio.h>
#include<string.h>
int main()
{
	char arr1[20] = "hello";
	char arr2[] = "world";
	char*p=strncat(arr1, arr2,5);
	printf("%s\n", p);
	printf("%s\n", arr1);
	return 0;
}

8.3 strncat函数模拟实现

#include<stdio.h>   // 标准输入输出库
#include<assert.h>  // 断言库

// 自定义的 strncat 函数
// 参数:arr1 - 目标字符串,arr2 - 源字符串,num - 要追加的字符数
// 返回值:指向目标字符串的指针
char* mystrncat(char* arr1, const char* arr2, size_t num)
{
    assert(arr1 && arr2);  // 确保目标指针和源指针都不为 NULL

    char* p = arr1;        // 保存目标字符串的起始地址,用于返回

    // 找到目标字符串的末尾(即 '\0' 的位置)
    while (*arr1)
    {
        arr1++;
    }

    // 从源字符串复制最多 num 个字符到目标字符串的末尾
    int i = 0;
    for (i = 0; arr2[i] && i < num; i++)
    {
        arr1[i] = arr2[i];
    }

    // 如果 num 小于 0,则在目标字符串后添加结束符(但 num 是 size_t,不可能小于 0)
    if (num < 0)
    {
        arr1[i] = 0;
    }

    return p;  // 返回目标字符串的起始地址
}

int main()
{
    char arr1[20] = "hello ";      // 目标字符串
    char arr2[] = "worldCCCCC";        // 源字符串
    char* ret = mystrncat(arr1, arr2, 5);  // 调用自定义函数,追加前 3 个字符

    printf("%s", ret);            // 输出结果:hellowor
    return 0;
}

九. strncmp函数的使用

9.1 strncmp函数理解

strncmp 是 C 标准库中的一个字符串比较函数,用于比较两个字符串的前 n 个字符。它的主要作用是判断两个字符串是否相等,或者在字典序(ASCII 码顺序)上的大小关系。


函数原型

int strncmp(const char *str1, const char *str2, size_t n);
  • str1:第一个字符串(不会被修改)。
  • str2:第二个字符串(不会被修改)。
  • n:最多比较的字符数。
  • 返回值
    • < 0str1 的前 n 个字符在字典序上小于 str2
    • = 0str1 的前 n 个字符与 str2 完全相同。
    • > 0str1 的前 n 个字符在字典序上大于 str2

strncmp 的工作原理:

  1. 逐个字符比较
    • 从 str1 和 str2 的第一个字符开始比较,直到遇到不同的字符或比较完 n 个字符。
  2. 比较规则
    • 如果 str1 的字符 ASCII 码值 < str2 的字符,返回 负数
    • 如果 str1 的字符 ASCII 码值 > str2 的字符,返回 正数
    • 如果前 n 个字符完全相同,返回 0
  3. 提前终止条件
    • 遇到 \0(字符串结束符)时停止比较。
    • 比较完 n 个字符时停止。

9.2 strncmp函数使用示例

#include<stdio.h>
#include<string.h>
int main()
{
	char arr1[] = "abcdef";
	char arr2[] = "abcggg";
	int ret = strncmp(arr1, arr2, 5);
	if (ret > 0)
		printf("abcdef>abcggg\n");
	else if (ret < 0)
		printf("abcdef<abcggg\n");
	else
		printf("=\n");
	return 0;
}

十. strstr函数的使用与模拟实现

10.1 strstr函数理解

strstr 是 C 标准库中的一个字符串查找函数,用于在一个字符串中查找另一个字符串的首次出现位置。

函数原型

char *strstr(const char *haystack, const char *needle);
    • 参数
      • haystack:被搜索的主字符串
      • needle:要查找的子字符串
    • 返回值
      • 如果找到,返回指向主字符串中子字符串首次出现位置的指针
      • 如果未找到,返回 NULL

    功能说明:

    strstr 函数会扫描 haystack 字符串,查找 needle 字符串的第一次出现。查找是区分大小写的。

    10.2 strstr函数使用示例

    #include<stdio.h>
    #include<string.h>
    int main()
    {
    	char arr1[] = "I LOVE CHAIN";
    	char arr2[] = "LOVE";
    	char* p = strstr(arr1, arr2);
    	if (p != NULL)
    		printf("查找成功: %s\n", p);
    	else
    		printf("抱歉 查找失败\n");
    }

    10.3 strstr函数模拟实现

    #include<stdio.h>   // 标准输入输出库
    #include<string.h>  // 字符串操作库
    #include<assert.h>  // 断言库
    
    // 自定义的 strstr 函数
    // 参数:str1 - 被查找的字符串,str2 - 要查找的子串
    // 返回值:如果找到,返回子串在 str1 中的起始地址;否则返回 NULL
    char* my_strstr(const char* str1, const char* str2)
    {
        assert(str1 && str2);  // 确保 str1 和 str2 都不为 NULL
    
        char* p = (char*)str1;  // 用于遍历 str1
        char* s1 = NULL;        // 用于临时记录 str1 的当前位置
        char* s2 = NULL;        // 用于遍历 str2
    
        // 如果要查找的子串是空字符串,直接返回 str1
        if (*str2 == '\0')
            return (char*)str1;
    
        // 遍历 str1
        while (*p)
        {
            s1 = p;            // 记录当前查找的起始位置
            s2 = (char*)str2;  // 每次从 str2 的开头开始匹配
    
            // 逐个字符比较,直到字符不匹配或任一字符串结束
            while (*s1 && *s2 && *s1 == *s2)
            {
                s1++;
                s2++;
            }
    
            // 如果 str2 已经遍历完(即找到完整匹配),返回起始位置 p
            if (*s2 == '\0')
                return p;
    
            p++;  // 继续查找下一个位置
        }
    
        return NULL;  // 遍历完 str1 仍未找到,返回 NULL
    }
    
    int main()
    {
        char arr1[] = "I LOVE CHINA";  // 被查找的字符串
        char arr2[] = "LOVE";      // 要查找的子串
    
        char* ret = my_strstr(arr1, arr2);  // 调用自定义查找函数
    
        if (ret != NULL)
        {
            printf("查找成功:%s", ret);  // 
        }
        else
        {
            printf("查找失败");
        }
    
        return 0;
    }

    十一. strtok函数的使用与模拟实现

    11.1 strtok函数理解

    strtok 是 C 标准库中的一个字符串分割函数,用于将一个字符串按照指定的分隔符(delimiters)拆分成多个子字符串(tokens)。


    函数原型

    #include <string.h>  // 需要包含头文件
    
    char *strtok(char *str, const char *delimiters);
    
    • str:待分割的字符串(首次调用时传入,后续调用传 NULL)。

    • delimiters:分隔符集合(如 ", \t \n" 表示按空格、逗号、制表符、换行符分割)。

    • 返回值

      • 成功时返回下一个子字符串(token)的指针。

      • 如果没有更多子字符串,返回 NULL

    strtok 的工作原理

    1. 首次调用

      • 传入待分割的字符串 strstrtok 找到第一个分隔符,将其替换为 \0,并返回第一个子字符串的指针。

    2. 后续调用

      • 传入 NULLstrtok 会从上次结束的位置继续查找下一个分隔符,并返回下一个子字符串。

    3. 结束条件

      • 当所有子字符串都被提取后,返回 NULL

    为什么后续调用传入NULL?

    原因如下:

    1. strtok 的工作原理

    strtok 是一个状态ful(stateful)函数,它会记住上一次处理的位置。具体来说:

    • 首次调用时,strtok 接收一个字符串(如 str)和分隔符(如 delimiters),它会从该字符串的起始位置开始扫描,找到第一个不包含分隔符的子字符串(token),并返回它。

    • 后续调用时,strtok 需要继续从上次结束的位置开始扫描剩余的部分。为了告诉 strtok 继续处理同一个字符串,需要传入 NULL 作为第一个参数。如果传入一个新的字符串,strtok 会重置内部状态,开始处理新的字符串。

    2. 为什么传入 NULL

    • 内部静态指针:strtok 内部使用一个静态指针(或全局变量)来记录当前处理的位置。首次调用时,这个指针被初始化为传入字符串的地址;后续调用时,传入 NULL 表示“继续处理上次的字符串”。

    • 避免重置状态:如果后续调用传入一个新的字符串(非 NULL),strtok 会重置内部指针,导致之前的分割状态丢失。

    11.2 strtok函数使用示例

    #define _CRT_SECURE_NO_WARNINGS
    #include <stdio.h>
    #include <string.h>
    
    int main() {
        char str[] = "hello,world;this|is-a.test";
        const char* delimiters = ",;|-.";  // 分隔符可以是逗号、分号、竖线、横线、点
    
        // 首次调用,传入 str
        char* token = strtok(str, delimiters);
        while (token != NULL) {
            printf("Token: %s\n", token);
            token = strtok(NULL, delimiters);  // 后续调用传 NULL
        }
    
        return 0;
    }
    

    11.3 strtok注意事项

    1. 修改原字符串

      • strtok 会直接修改传入的字符串,将分隔符替换为 \0。因此,不能对常量字符串(如 "hello,world")使用 strtok,否则会导致段错误(Segmentation Fault)。

      • ✅ 正确:char str[] = "hello,world";(可修改)

      • ❌ 错误:char *str = "hello,world";(字符串常量,不可修改)

    2. 连续分隔符

      • 如果字符串中有连续的分隔符(如 "a,,b"),strtok 会跳过它们,不会返回空字符串。

    3. 不能嵌套调用

      • 由于 strtok 使用静态存储,不能同时用于多个字符串的分割。例如:
        char str1[] = "a,b";
        char str2[] = "1;2";
        char *token1 = strtok(str1, ",");  // 第一次调用
        char *token2 = strtok(str2, ";");  // 会破坏 str1 的分割状态!

    十二. strerror函数的使用与模拟实现

    12.1 strerror函数理解

    strerror 是 C 标准库中的一个函数,用于将错误代码(errno)转换为可读的错误信息字符串。它定义在 <string.h> 头文件中,通常与 errno(定义在 <errno.h>)一起使用,以便在程序出错时提供更友好的错误提示。


    函数原型

    #include <string.h>
    char *strerror(int errnum);
    
    • 参数

      • errnum:错误代码(通常是 errno 的值)。

    • 返回值

      • 返回一个指向错误描述字符串的指针(静态存储区,不可修改)。

    strerror 的用途

    • 在不同的系统和C语言标准库的实现中都规定了⼀些错误码,⼀般是放在 errno.h 这个头文件中说明的,C语言程序启动的时候就会使用⼀个全局的变量 errno 来记录程序的当前错误码,只不过程序启动的时候errno是 0,表示没有错误,当我们在使用标准库中的函数的时候发生了某种错误,就会将对应的错误码,存放在 errno 中,而⼀个错误码的数字是整数很难理解是什么意思,所以每⼀个错误码都是有对应的错误信息的。strerror函数就可以将错误对应的错误信息字符串的地址返回

    12.2 strerror函数使用

    #include <errno.h>
    #include <string.h>
    #include <stdio.h>
    //打印0~10这些错误码对应的信息
    int main()
    {
    	int i = 0;
    	for (i = 0; i <= 10; i++) {
    		printf("%d.%s\n",i, strerror(i));
    	}
    	return 0;
    }

    示例

    #include <stdio.h>
    #include <string.h>
    #include <errno.h>
    int main()
    {
    	//C语言可以打开文件
    	//fopen
    	//如果以读的形式打开文件,文件是必须要存在的,如果文件不存在,则打开文件失败
    	//fopen函数就会将错误码放在errno
    	//同时函数就会返回NULL
    	FILE* pFile;
    	pFile = fopen("5_20.text", "r");
    	if (pFile == NULL)
    		printf( %s\n", strerror(errno));
    	return 0;
    }

    12.3 perror函数

    perror 是 C 标准库(<stdio.h>)中的一个函数,用于打印与 errno 相关的错误信息。它的原型如下:

    void perror(const char *s);
    

    功能

    • 根据全局变量 errno(通常由系统调用或库函数设置)打印对应的错误描述。
    • 如果 s 不是 NULL 或空字符串,perror 会先输出 s,后跟一个冒号 : 和空格,然后输出 errno 对应的错误信息。
    • 如果 s 是 NULL 或空字符串,则只输出 errno 的错误信息。

    使用示例

    int main() {
        FILE* fp = fopen("nonexistent_file.txt", "r");
        if (fp == NULL) {
            perror("Failed to open file");
        }
        return 0;
    }

    与 strerror(errno) 的区别

    • perror 直接打印错误信息到 stderr(标准错误输出)。
    • strerror(errno) 返回错误信息的字符串,可以自定义输出方式:
    fprintf(stderr, "Error: %s\n", strerror(errno));

    以上就是字符函数和字符串函数上篇的全部内容 希望能够为您提供帮助

    往期回顾

    《C 语言字符串操作从入门到实战(上篇):字符分类、转换及strlen/strcpy等函数详解》

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

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

    相关文章

    百度飞桨PaddleOCR 3.0开源发布 OCR精度跃升13%

    百度飞桨 PaddleOCR 3.0 开源发布 2025 年 5 月 20 日&#xff0c;百度飞桨团队正式发布了 PaddleOCR 3.0 版本&#xff0c;并将其开源。这一新版本在文字识别精度、多语种支持、手写体识别以及高精度文档解析等方面取得了显著进展&#xff0c;进一步提升了 PaddleOCR 在 OCR …

    Xilinx 7Series\UltraScale 在线升级FLASH STARTUPE2和STARTUPE3使用

    一、FPGA 在线升级 FPGA 在线升级FLASH时&#xff0c;一般是通过逻辑生成SPI接口操作FLASH&#xff0c;当然也可以通过其他SOC经FPGA操作FLASH&#xff0c;那么FPGA就要实现在启动后对FLASH的控制。 对于7Series FPGA&#xff0c;只有CCLK是专用引脚&#xff0c;SPI接口均为普…

    数字孪生驱动的离散制造智能升级:架构设计与工程实践

    针对离散制造行业多品种、小批量的生产特性&#xff0c;本文提出一种基于数字孪生的智能制造解决方案。以某国家级智能制造试点示范项目为载体&#xff0c;构建"云-边-端"协同的数字孪生系统&#xff0c;实现设备综合效率&#xff08;OEE&#xff09;提升28.7%、订单…

    9.4在 VS Code 中配置 Maven

    在 VS Code 中配置 Maven 需要完成 Maven 环境安装 一、安装 Maven&#xff08;如果未安装&#xff09; 下载 Maven 访问 Apache Maven 官网&#xff0c;下载最新版本的 Maven&#xff08;如apache-maven-3.9.9-bin.zip&#xff09;。 解压文件 将下载的 ZIP 文件解压到本地目…

    新能源汽车充电桩资源如何利用资源高效配置?

    新能源汽车充电桩资源的高效配置是实现绿色交通转型的关键环节。随着新能源汽车保有量的快速增长&#xff0c;充电基础设施的供需矛盾日益凸显。如何优化充电桩资源布局、提升使用效率、平衡不同场景需求&#xff0c;成为当前亟待解决的问题。以下是几点关于充电桩资源高效配置…

    LeetCode --- 450周赛

    题目列表 3550. 数位和等于下标的最小下标 3551. 数位和排序需要的最小交换次数 3552. 网格传送门旅游 3553. 包含给定路径的最小带权子树 II 一、数位和等于下标的最小下标 直接模拟计算数位和即可&#xff0c;代码如下 // C class Solution { public:int smallestIndex(ve…

    SpringBoot中消息转换器的选择

    SpringBoot返回xml-CSDN博客 是返回JSON 还是XML 是由内容协商机制确认的,SpringBoot为了开发便利性,如果我没有该消息转换器,默认就返回了JSON,如果需要XML那么,引入 <dependency><groupId>com.fasterxml.jackson.dataformat</groupId><artifactId>…

    基于点标注的弱监督目标检测方法研究

    摘要 在计算机视觉领域&#xff0c;目标检测需要大量精准标注数据&#xff0c;但人工标注成本高昂。弱监督目标检测通过低成本标注训练模型&#xff0c;成为近年研究热点。本文提出一种基于点标注的弱监督目标检测算法&#xff0c;仅需在图像中物体中心点标注&#xff0c;即可高…

    超越OpenAI CodeX的软件工程智能体:Jules

    目前AI编码代理&#xff08;coding agent&#xff09;领域正迅速崛起&#xff0c;Google推出了一款名为Jules的非同步编码代理&#xff08;asynchronous coding agent&#xff09;&#xff0c;主要针对专业开发者&#xff0c;与传统在开发环境中直接辅助编码的Cursor或Windsurf…

    轻量化MEC终端 特点

    MEC&#xff08;多接入边缘计算&#xff09;解决方案通过将计算能力下沉至网络边缘&#xff0c;结合5G网络特性&#xff0c;已在多个行业实现低延迟、高可靠、高安全的应用部署。以下从技术架构、核心优势及典型场景三方面进行总结&#xff1a; 一、技术架构 分层设计‌ MEC架…

    NIST提出新型安全指标:识别潜在被利用漏洞

    美国国家标准与技术研究院&#xff08;NIST&#xff09;近日公布了一项突破性的安全指标&#xff0c;旨在评估哪些软件漏洞可能已被利用——即使相关组织尚未察觉。 这项由前NIST专家Peter Mell和网络安全与基础设施安全局&#xff08;CISA&#xff09;Jonathan Spring共同完成…

    List介绍

    什么是List 在集合框架中&#xff0c;List是一个接口&#xff0c;继承自Collection Collection也是一个接口&#xff0c;该接口中规范了后序容器中常用的一些方法 Iterable也是一个接口&#xff0c;表示实现该接口的类是可以逐个元素进行遍历的&#xff0c;具体如下&#xff1…

    正则表达式全解:一文学会正则表达式【附在线正则表达式练习网站】

    1.正则表达式的作用 案例演示 先给大家看一个例子,在以下文本中存储了一些职位信息: Python3 高级开发工程师 上海互教教育科技有限公司上海-浦东新区2万/月02-18满员 测试开发工程师(C++/python) 上海墨鹍数码科技有限公司上海-浦东新区2.5万/每月02-18未满员 Python3 …

    Nginx-详解(二)

    nginx 常见模块 第三方模块是对nginx 的功能扩展&#xff0c;第三方模块需要在编译安装nginx 的时候使用参数-- add-modulePATH指定路径添加&#xff0c;有的模块是由公司的开发人员针对业务需求定制 开发的&#xff0c;有的模块是开源爱好者开发好之后上传到github进行开源的…

    MCP、MCPHub、A2A、AG-UI概述

    MCP Model Context Protocol&#xff0c;模型上下文协议&#xff0c;Anthropic于2024年开源的标准协议&#xff0c;旨在统一AI模型与数据源的交互方式&#xff0c;提升数据访问的便捷性和可靠性&#xff0c;提供标准化的工具调用、资源管理和提示词功能。 MCP的基本定义&…

    [Linux]磁盘分区及swap交换空间

    linux磁盘分区 计算机容量单位&#xff1a;一般用B&#xff0c;KB&#xff0c;MB&#xff0c;GB&#xff0c;TB&#xff0c;PB&#xff0c;EB&#xff0c;ZB&#xff0c;YB&#xff0c;BB来表示。 它们之间的关系是&#xff1a; 1KB (Kilobyte 千字节)1024B, 1MB (Megabyte 兆…

    Linux常见指令合集+知识点

    Linux有一条设计理念&#xff1a;Linux中一切皆文件&#xff1b;这样的设计理念让Linux可以用一种统一的方式对Linux中的不同文件/设备进行管理&#xff1b;&#xff08;也就是键盘、显示器等在Linux中也算文件&#xff09; 文件内容属性&#xff0c;指令一般都是对文件进行操…

    nginx 基于IP和用户的访问

    nginx的下载 yum install nginx.x86_64 -y 启动服务 systemctl enable --now nginx.service 查看服务目录 [rootwebserver ~]# rpm -ql nginx /usr/bin/nginx-upgrade /usr/lib/systemd/system/nginx.service /usr/share/man/man3/nginx.3pm.gz /usr/share/man/man8/nginx…

    【Linux】系统程序−进度条

    文章目录 一、准备知识1.回车与换行1.1 回车1.2 换行 2. 行缓冲区3. 倒计时程序 二、进度条程序1. 版本1 一、准备知识 在讲解进度条之前&#xff0c;先讲解几个概念 1.回车与换行 1.1 回车 回车&#xff1a;\r 作用&#xff1a;将光标移动到当前行的行首&#xff08;水平回…

    Linux(6)——第一个小程序(进度条)

    目录 一、行缓冲区的概念 二、\r与\n 三、进度条代码书写与展示 1.如何表示进度条是在加载的 2.整体框架 3.书写 3.1makefile: 3.2process.h: 3.3process.c: 3.4main.c&#xff1a; 3.5美化 一、行缓冲区的概念 首先&#xff0c;我们来见一见行缓冲区&#xff0c;…