用C语言构建简单Shell:系统编程初学者指南
我如何用C语言构建简单Shell——系统编程初学者指南 (1/3)
#cli #c #systemprogramming #memorymanagement
第1部分:在自定义Shell中读取用户输入(C编程)
在我的自定义shell项目的这一部分中,我将解释如何在C中动态读取用户输入。在shell环境中正确处理用户输入是至关重要的,因为命令的长度可能不同。我没有使用固定大小的缓冲区,而是实现了动态内存分配方法以获得更好的灵活性。
理解 _read_command_ 函数
read_command() 函数负责:
动态读取用户输入
处理内存分配和重新分配以避免缓冲区溢出
确保输入字符串的正确终止
代码分解
#ifndef READ_COMMAND_H
#define READ_COMMAND_H

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#define INT_BUFFER_SIZE 32 // 初始缓冲区大小

char *read_command();

#endif
头文件保护 (#ifndef READ_COMMAND_H): 防止多次包含。
常量定义 (INT_BUFFER_SIZE): 设置输入存储的初始缓冲区大小。
_read_command()_ 的实现
char *read_command()
{
char *command = malloc(INT_BUFFER_SIZE * sizeof(char));
if (!command)
{
perror("Memory allocation failed");
exit(EXIT_FAILURE);
}
内存分配 (malloc): 最初为存储用户输入分配 INT_BUFFER_SIZE 字节。
错误处理: 如果 malloc 失败,程序打印错误并退出。
int size = INT_BUFFER_SIZE;
int length = 0;
int c;
size: 跟踪当前缓冲区大小。
length: 跟踪实际读取的字符数。
c: 存储从 _getchar()_ 获取的输入字符。
处理动态输入增长
while ((c = getchar()) != '\n' && c != EOF)
{
if (length >= (size - 1))
{
size *= 2; // 需要时将缓冲区大小加倍
char *new_command = realloc(command, (size + 1));
if (!new_command)
{
free(command);
perror("Memory reallocation failed");
exit(EXIT_FAILURE);
}
command = new_command;
}
command[length++] = c;
}
动态扩展内存 _(realloc)_
如果输入超过分配的大小,缓冲区会加倍 _(size = 2)_。
_realloc_ 尝试调整缓冲区大小;如果失败,释放内存并显示错误。
存储字符
来自 _getchar()_ 的每个字符按顺序存储在 _command[length++]_
完成输入
command[length] = '\0'; // 空终止字符串
return command;
空终止 (\\0): 确保字符串正确终止,以便它可以作为有效的C字符串处理。
返回输入: 函数返回动态分配的字符串以供进一步使用。
为什么采用这种方法?
📌 避免缓冲区溢出: _scanf_ _gets_ 不同,此方法根据需要动态扩展。
📌 高效的内存管理: _realloc_ 优化内存分配,而不是预分配大块内存。
📌 更好的灵活性: 可以处理长命令而无需任意限制。
Aa