use*_*113 3 c unix compare cmp output
因此,我首先要说的是这是一门课程,我假设如果cmp返回一些奇怪的信息,教授将不会真正在意它们是否相同。我正在尝试将我的名为uout的代码的输出与正确的输出(在correct0文件中)进行比较。但是,问题在于它返回“ cmp:uout上的EOF”。通过一点点挖掘,我发现EOF表示它们在较短文件的末尾都是相同的,而较短文件是以EOF命名的文件,因此我从中收集到的是它们是相同的,直到uout结束为止。然而问题是,它绝对不会以短时间结束。在文本编辑器中打开并手动检查空格,行号和列号等时,所有内容都完全匹配。
为了说明我的观点,这里是使用ctrl-a + ctrl-v直接复制的文件:
正确0 http://pastebin.com/Bx7SM7rA
uout http://pastebin.com/epMFtFpM
如果有人知道出了什么问题并且可以简单地解释,我将不胜感激。我已经检查了多次,找不到任何问题。也许这很简单,我只是看不到它,但是到目前为止,我所看到的一切似乎都表明文件是相同的,直到“较短的文件”结束为止,而且即使我将执行从
cmp correct0 uout
Run Code Online (Sandbox Code Playgroud)
至
cmp uout correct0
Run Code Online (Sandbox Code Playgroud)
两个实例最终都返回
cmp: EOF on uout
Run Code Online (Sandbox Code Playgroud)
小智 5
您上传的文件是相同的。这可能是行尾问题。DOS / Windows使用“ \ r \ n”作为行尾,但是Unix / Linux仅使用“ \ n”。
用于检查问题所在的Linux机器上最好的实用程序是“ od”(八进制转储)或任何其他用于以二进制格式显示文件的命令。那是:
$ od -c uout.txt
0000000 E n t e r t h e n u m b e r
0000020 s f r o m 1 t o 1 6 i
0000040 n a n y o r d e r , s e p
0000060 a r a t e d b y s p a c e s
0000100 : \r \n \r \n 1 6 3 2 1
0000120 3 \r \n 5 1 0 1 1 8 \r
0000140 \n 9 6 7 1 2 \r \n
0000160 4 1 5 1 4 1 \r \n \r \n R
0000200 o w s u m s : 3 4 3 4 3
0000220 4 3 4 \r \n C o l u m n s u m
0000240 s : 3 4 3 4 3 4 3 4 \r \n
0000260 D i a g o n a l s u m s : 3
0000300 4 3 4 \r \n \r \n T h e m a t r
0000320 i x i s a m a g i c s q
0000340 u a r e
0000344
Run Code Online (Sandbox Code Playgroud)
如您所见,这里的行尾为\ r \ n。由于您已经打开并复制了粘贴的文件,因此这表示您的计算机首选项,而不是实际的行结尾。您也可以尝试使用dos2unix实用程序转换行尾。