gpt4 book ai didi

c - 一般情况下,将 ungetc() 包装起来,而不使用 put() gets() 和流

转载 作者:行者123 更新时间:2023-11-30 16:54:09 25 4
gpt4 key购买 nike

我正在将 net-snmp 移植到一个嵌入式平台,该平台对文件系统的访问权限有限,但我偶然发现了一个大问题。有一部分核心代码使用了 ungetc() 函数,但我没有。当然有两种解决方案:

A)使用我拥有的东西编写我自己的 ungetc()

B) 修改 net-snmp 代码以便在不使用 ungetc() 的情况下获得相同的结果

解决方案(B)最终将在 net-snmp 编码者邮件列表中讨论,因为需要深入了解库的内部结构,所以让我们重点关注(A)的可行性

我的嵌入式系统上有:

fopen()
fclose()
fcreate()
fwrite()
fread()
fdelete()
fclear()
fcopy()
ffindfirst()
ffindnext()
frename()
fgetsize()
ftell()
fseek()
fgetc()
fgets()

主要区别在于我的文件函数使用 INT32* 文件句柄而不是 FILE* 类型。我没有 FILE* 类型。

ungetc() 函数的作用基本上是“将字符放回流中”,可以是刚刚读取的字符,也可以是另一个字符。

在第一种情况下,解决方案很简单,我使用 fseek() 将指针向后倒一个位置。

但在第二种情况下我遇到了问题。我将修改流而不是文件,除非我没有流!我直接读取文件。

使用 ungetc() 你可以做类似的事情

FILE *fp = fopen("file.txt", "r");
int c = getc (fp);
if( c == 'a' ) ungetc ('b', fp);

如果“file.txt”包含“abcdefghi”,则使用 gets() 进行后续读取将读取“bbcdefghi”而不是“abcdefghi”,因为流中的内容已更改,但文件未更改!

如果我没有“流”,如何复制此行为?我的 getc() 和 gets() 从 INT32* 文件句柄读取,但没有等效的 puts() 或 putc()。

我只能使用 fwrite() 进行写入,但这会改变 NV 内存上的内容。

感谢您的见解

最佳答案

这是我解决这个问题的方法。我为文件句柄创建了一个更复杂的结构,它不仅包含句柄本身,还包含文件名、文件大小和保存文件全部内容的缓冲区。它应该只加载我需要的文件部分,但我的是嵌入式应用程序,我知道我不会打开大文件,所以我没有打扰。

一旦你有了“流”,将字符弹出和弹出就变得很简单了。

typedef struct _myfile {
_FS_HANDLE handle; /* file descriptor */
CHAR* fname; /* file name */
UINT32 fsize; /* file size */
CHAR* buffer; /* file buffer */
} *my_FILE;

int my_ungetc(int c, my_FILE stream)
{
if (stream)
{
UINT32 pointer = _fs_tell(stream->handle);
if (pointer > 0)
{
_fs_seek(stream->handle,pointer - 1);
stream->buffer[pointer - 1] = c;
return c;
}
}
else
{
printf("ERROR! stream is NULL!\r\n");
}
return EOF;
}

void *my_fopen(const char *filename, const char *mode)
{
my_FILE fp = _mem_alloc(sizeof(struct _myfile));
fp->fname = strdup(filename);
if (mode == "r")
{
fp->handle = _fs_open((CHAR*)filename, OPEN_READ);
if (fp->handle) fp->fsize = _get_size_with_handle(fp->handle);
if (fp->fsize)
{
fp->buffer = _mem_alloc(fp->fsize);
if (fp->buffer)
{
if (_fs_read(fp->handle,fp->buffer,fp->fsize))
{
_fs_seek(fp->handle,0);
}
else
{
printf("ERROR: unable to read %d bytes from %s\r\n",fp->fsize,filename);
}
}
else
{
printf("ERROR in my_fopen(\"%s\",\"r\"): could not alloc %d bytes for buffer\r\n",filename,fp->fsize);
}
}
else
{
fp->buffer = NULL;
printf("File \"%s\" is empty\r\n");
}
return fp;
}
else if (mode == "w")
{
fp->handle = _fs_open((CHAR*)filename, OPEN_WRITE);
if (fp->handle) fp->fsize = _get_size_with_handle(fp->handle);
fp->buffer = NULL;
return fp;
}
else
{
printf("File open mode %s not supported\r\n",mode);
return NULL;
}
}

关于c - 一般情况下,将 ungetc() 包装起来,而不使用 put() gets() 和流,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40636180/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com