我正在尝试从文本文件中读取数据(时间)。并将其转换为可以DiffTime到当前系统时间的东西。
我现在已经非常接近让这个工作正常了,我可以品尝它,但我遇到了一个我无法解决的问题。 (我对C语言有一个非常基本的把握)。
此程序从文本文件中读取数据,将其拆分为两个char数组,然后尝试使用atoi
将其转换为整数。但是,我在第二次atoi
电话时遇到问题。
从最底层的两个printf
陈述中,我应该得到:
12 34
但由于某种原因,我得到了这些方面的东西。
12 3412
我认为atoi
超出了其中一个char数组的边界,或者我的char数组太长或太短。无论哪种方式,我都无法理解正在发生的事情。
#include <fcntl.h>
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <string.h>
#define COPYMODE 0644
int main (int argc, char *argv[]){
int i, nRead, fd;
int source;
int ihour;
int imin;
int STATE_OK = 0;
int STATE_WARNING = 1;
int STATE_CRITICAL = 2;
int STATE_UNKNOWN = 3;
/* indicates if system is paused 1 = System is paused, 0 = System running */
int system_paused = 0;
char filebuf[5];
char hourbuf[2];
char minbufer[2];
if((fd = open(argv[1], O_RDONLY)) == -1)
{
printf("failed open : %s", argv[1]);
}
else
{
nRead = read(fd, filebuf, 5);
}
close(source);
printf("filebuffer %s\n", filebuf);
hourbuf[0] = filebuf[0];
hourbuf[1] = filebuf[1];
printf("Hour Buffer %c%c\n", hourbuf[0],hourbuf[1]);
minbufer[0] = filebuf[2];
minbufer[1] = filebuf[3];
printf("Min Buffer %c%c\n", minbufer[0],minbufer[1]);
imin = atoi(minbufer);
ihour = atoi(hourbuf);
printf("hour as int %d\n", ihour);
printf("min as int %d\n", imin);
return 0;
}
答案 0 :(得分:10)
您需要null终止字符串。使hourbuf和minbufer 1更长,并在调用atoi之前将0放在最后。两个缓冲区在堆栈上相邻,因此读取minbufer也会扫描到hourbuf。
答案 1 :(得分:8)
您忘记使用零终止char
个缓冲区。
char hourbuf[2];
char minbufer[2];
应该是
char hourbuf[3];
char minbufer[3];
hourbuf[2] = '\0';
minbufer[2] = '\0';
答案 2 :(得分:1)
atoi
假设它的参数是一个C风格的字符串,这意味着它必须包含一个尾随的空字符。
您手工制作的伪弦不能确保这一点。
解决方案是扩大它们并将最后一个元素设置为'\0
:
char hourbuf[3];
int hour;
...
hourbuf[0] = filebuf[0];
hourbuf[1] = filebuf[1];
hourbuf[2] = '\0';
hour = atoi(hourbuf);
答案 3 :(得分:-1)
你忘记了null终止:
minbufer[2] = '\0'