『壹』 eof是什么意思
eof在c语言中表示文件结束符。
在while循环中以EOF作为文件结束标志,这种以EOF作为文件结束标志的文件,必须是文本文件。在文本文件中,数据都是以字符的ASCII码值的形式存放的。
EOF是一个计算机术语,为EndOfFile的缩写,在操作系统中表示资料源无更多的资料可读取。资料源通常称为档案或串流,通常在文本的最后存在此字符表示资料结束。
C语言简介
C语言是一门面向过程的计算机编程语言,与C++、Java等面向对象编程语言有所不同。C语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、仅产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。
C语言描述问题比汇编语言迅速,工作量小、可读性好,易于调试、修改和移植,而代码质量与汇编语言相当。C语言一般只比汇编语言代码生成的目标程序效率低10%~20%。因此,C语言可以编写系统软件。
C语言不但执行效率高而且可移植性好,可以用来开发应用软件、驱动、操作系统等。C语言也是其它众多高级语言的鼻祖语言,所以说学习C语言是进入编程世界的必修课。
『贰』 标识文档结束的符号是什么样的
不同的软件是不一样的,例如编辑程序和字处理软件就不是相同的符号。
『叁』 谈谈C语言中的结束符EOF
计算机中检测文件结尾方法的一种方法:在文件的末尾放特殊的字符标记结尾。
在C语言中,使用getchar()读取文件,检测到末尾时会返回一个特殊值,即返回EOF。使用
scanf()函数时同样返回EOF。
我们不需要定义EOF,EOF在头文件stdio.h中定义,通常EOF被定义为-1。
在进行键盘输入时,同样可以使用EOF作为输入的结尾条件,在Windows中就使用快捷键Ctrl+z,作为文件结尾信号。如下边的示例:
上述示例中,在while循环中使用getchar()函数,不断读取字符,将读取到的字符赋值给ch变量,直到输入EOF字符结束,这里的EOF不能输入EOF三个字符,在Windows中,当我们输入Ctrl+z时,就会识别为EOF,就会结束输入。
『肆』 文件名的最后一个字符可以是空格么
可以是空格。不过空格是无效字符,比如说同一文件夹下有个文件名为1,则文件名为1+空格的文件视为同名。。。不能创建。。。
至于删不掉,可能是dos下长文件名,在windows下没显示出来。。。。。。。。
可能是文件夹病毒。。。。
打开命令提示符。。。
用rd
命令删除试试。。。(rd
文件名)
如果是隐藏文件。。。
则先用attribute(attrib
-s
-r
-h
文件名)
『伍』 C语言 文件的结束符是什么玩意
C语言中,文来件结束符就源是EOF(End of File)。但这并不是一个实实在在存在的东西,是一个标志:若读取到文件末尾的时候,即没有数据可供读取的时候,读文件函数(fgets, fgetc等)就会返回EOF值。
C语言中,EOF是个宏,在stdio.h文件中进行定义:
#define EOF (-1)
即:EOF就是整型数-1。
我们写程序,可以通过判断读文件函数的返回值,来判断是否到了文件尾。
C语言中,标准输入也是一种特殊的文件,但这个"文件”并没有具体的结束位置,所以,只能人为的创造结束位置 :
windows下,在输入的空行位置,按ctrl+z可产生EOF
linux下,在输入时,按ctrl+d可产生EOF
『陆』 批量在文件名末尾增加字符
批量在文件名后面添加相同的字符:
步骤1,下载上面的工具后安装打开,然后点击左上角的【添加文件】按钮,批量将文件全部添加到软件中(打开文件所在文件夹,单击一个文件,然后同时按住ctrl+A键,就可以选中全部文件)。
『柒』 什么是文件结束符
文件结束符检测文复件指制针是否已在尾部 EOF
EOF只是一个编译器事先约定好的常量,不是用来输入的.
在UNIX系统中用C语言对文件操作,文件结束符用组合键表示
EOF()
字符是^D (0x0d)
Win 中是^Z (0x1a)
很多人说是ctrl+z,其实不是,ctrl+z在程序里就是中断程序,一个快捷键而已
『捌』 我想问一下:txt文件的文件结束符EOF是不是就是回车键还是其他什么东西
EOF 是 End Of File 的缩写。
在C语言中,它是在标准库中定义的一个宏。#define EOF (-1)
人们经常误认为 EOF 是从文件中读取的一个字符。
其实,EOF 不是一个字符,它被定义为是 int 类型的一个负数(-1)。
EOF 也不是文件中实际存在的内容。
EOF 也不是只表示读文件到了结尾这一状态(这种状态可以用 feof() 来检测),它还能表示 I/O 操作中的读、写错误(通常可以用 ferror() 来检测)以及其它一些关联操作的错误状态。
『玖』 文件结束符EOF
哦,这个不是1楼说的那个样子的。是文件结束的标志,事实上是-1.可以稍微修改一下楼主的程序来做证明:
while(!in.eof())
{
temp=in.get();
cout<<int(temp)<<endl;
count++;
}
这个时候,会发现在输出count之前输出的最后一个是-1.
但是为什么会输出-1(也就是文件结束符号)呢?in.eof()返回的是in里面的EOF变量,这个变量在in读到文件的结束符时才会变为1。也就是说,只有当in.get()读过了eof的时候,in中的EOF变量才会编程1,in.get()才能返回1。
那为什么按照楼主给的代码里面的in>>temp写法,最后会输出两个c,而和get的输出不一样呢?这个是因为>>在处理的时候,如果碰到读入的是文件结束符,是不会将其写道缓存中的,那样的话,缓存中的字符串还是在读入eof之前的那个字符(这个代码里面也就是'c'),然后再赋值给temp的还是'c'了。
那如何可以比较完美的修改上面的代码呢?对于文件输入流来说,有一个指针指向的是当前读的字符串的下一位,每读一位,指针就往下移一位。就比如一个只有abc的input.txt的文件,我们现在读完了c,那么指针的状态是大致是下面这个样子:
a
b
c
EOF<--
注意,这个时候,in.eof()还不返回1,因为in这个输入流还没有读EOF这个文件结束符,但是in有一个函数peek()是读当前指针指向的这个位置的符号的。那么如果用in.peek()==EOF来最为判断的标准就比较好了。楼主的例子写成
while(in.peek()!=EOF)
{
in>>temp;
cout<<temp<<endl;
count++;
}
就可以了。
顺便说一句,第一段代码里面while的里面再嵌一个while没有必要吧...
还有,无论读还是写,最好都要养成在操作完毕调用close()关闭流的好习惯:)