字符串+文件处理函数.docx
《字符串+文件处理函数.docx》由会员分享,可在线阅读,更多相关《字符串+文件处理函数.docx(20页珍藏版)》请在冰豆网上搜索。
字符串+文件处理函数
C语言标准输入输出:
待续
printf格式输出到屏幕//把指定内存空间中内容格式输出到屏幕;
fprintf格式输出到磁盘//
scanf从屏幕格式输入//从stdin中格式读入到给定变量空间中
fscanf从磁盘格式输入
putchar字符输出到屏幕
puts字符串输出到屏幕
fputc字符输出到磁盘
fputs字符串输出到磁盘
getchar从屏幕得到一个字符//从stdin中读取一个字符,返回字符ASCII值
gets从屏幕得到一个字符串//从stdin中读取字符串,返回内存空间位置
fgetc从磁盘得到一个字符
fgets从磁盘得到一个字符串
fputc,fputs,putc,putchar,puts-outputofcharactersandstrings
SYNOPSIS
#include
intfputc(intc,FILE*stream);
intfputs(constchar*s,FILE*stream);
intputc(intc,FILE*stream);
intputchar(intc);
intputs(constchar*s);
DESCRIPTION
fputc()writesthecharacterc,casttoanunsignedchar,tostream.
fputs()writesthestringstostream,withoutitsterminatingnullbyte('\0').
putc()isequivalenttofputc()exceptthatitmaybeimplementedasamacrowhichevaluatesstreammorethanonce.
putchar(c);isequivalenttoputc(c,stdout).
puts()writesthestringsandatrailingnewlinetostdout.
RETURNVALUE
fputc(),putc()andputchar()returnthecharacterwrittenasanunsignedcharcasttoanintorEOFonerror.
puts()andfputs()returnanonnegativenumberonsuccess,orEOFonerror.
fgetc,fgets,getc,getchar,gets,ungetc-inputofcharactersandstrings
SYNOPSIS
#include
intfgetc(FILE*stream);
char*fgets(char*s,intsize,FILE*stream);
intgetc(FILE*stream);
intgetchar(void);
char*gets(char*s);
intungetc(intc,FILE*stream);
DESCRIPTION
fgetc()readsthenextcharacterfromstreamandreturnsitasanunsignedcharcasttoanint,orEOF
onendoffileorerror.
getc()isequivalenttofgetc()exceptthatitmaybeimplementedasamacrowhichevaluatesstream
morethanonce.
getchar()isequivalenttogetc(stdin).
gets()readsalinefromstdinintothebufferpointedtobysuntileitheraterminatingnewlineor
EOF,whichitreplaceswithanullbyte('\0').Nocheckforbufferoverrunisperformed(seeBUGS
below).
fgets()readsinatmostonelessthansizecharactersfromstreamandstoresthemintothebufferpointedtobys.ReadingstopsafteranEOForanewline.Ifanewlineisread,itisstoredintothebuffer.Aterminatingnullbyte('\0')isstoredafterthelastcharacterinthebuffer.
ungetc()pushescbacktostream,castto(铸造)unsignedchar,whereitisavailableforsubsequentreadoperations.Pushed-backcharacterswillbereturnedinreverseorder;onlyonepushbackisguaran‐teed.Callstothefunctionsdescribedherecanbemixedwitheachotherandwithcallstootherinputfunc‐tionsfromthestdiolibraryforthesameinputstream.
Fornonlockingcounterparts,seeunlocked_stdio(3).
RETURNVALUE
fgetc(),getc()andgetchar()returnthecharacterreadasanunsignedcharcasttoanintorEOFon
endoffileorerror.
gets()andfgets()returnsonsuccess,andNULLonerrororwhenendoffileoccurswhilenocharac‐
tershavebeenread.
ungetc()returnsconsuccess,orEOFonerror.
文件处理函数-待续
C语言中主要通过标准I/O函数来对文本文件进行处理。
相关的操作包括打开、读写、关闭与设置缓冲区。
相关的存取函数有:
fopen(),fclose(),fgetc(),fputc(),fgets(),fputs(),fprintf(),fscanf()等。
Truncate函数
定义函数:
inttruncate(constchar*path,off_tlength);
函数说明:
truncate()会将参数path指定的文件大小改为参数length指定的大小.如果原来的文件大小比参数length大,则超过的部分会被删去.
返回值:
执行成功则返回0,失败返回-1,错误原因存于errno.
FILE指针文件操作(fopen)
1.fopen
fopen:
则通过缓冲区来操作,读写都在缓冲区上
打开普通文件
带缓冲区
缓冲文件系统是借助文件结构体指针来对文件进行管理,通过文件指针来对文件进行访问,既可以读写字符、字符串、格式化数据,也可以读写二进制数据。
使用fopen()函数打开的文件会先将文件复制到缓冲区。
注意:
所下达的读取或写入动作,都是针对缓冲区进行存取而不是磁盘,只有当使用fclose()函数关闭文件时,缓冲区中的数据才会写入磁盘。
函数原型:
FILE*fopen(constchar*path,constchar*mode);
所需库:
返回值:
文件顺利打开后,指向该流的文件指针就会被返回。
如果文件打开失败则返回NULL,并把错误代码存在errno中。
参数说明:
参数path字符串包含欲打开的文件路径及文件名,参数mode字符串则代表着流形态。
mode有下列几种形态字符串:
r以只读方式打开文件,该文件必须存在。
r+以可读写方式打开文件,该文件必须存在。
rb+读写打开一个二进制文件,允许读写数据。
rw+读写打开一个文本文件,允许读和写。
w打开只写文件,若文件存在则文件长度清为0,即该文件内容会消失。
若文件不存在则建立该文件。
w+打开可读写文件,若文件存在则文件长度清为零,即该文件内容会消失。
若文件不存在则建立该文件。
a以附加的方式打开只写文件。
若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾,即文件原先的内容会被保留。
(EOF符保留)
a+以附加方式打开可读写的文件。
若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾后,即文件原先的内容会被保留。
(原来的EOF符不保留)
wb只写打开或新建一个二进制文件;只允许写数据。
wb+读写打开或建立一个二进制文件,允许读和写。
ab+读写打开一个二进制文件,允许读或在文件末追加数据。
at+打开一个叫string的文件,a表示append,就是说写入处理的时候是接着原来文件已有内容写入,不是从头写入覆盖掉,t表示打开文件的类型是文本文件,+号表示对文件既可以读也可以写。
上述的形态字符串都可以再加一个b字符,如rb、w+b或ab+等组合,加入b字符用来告诉函数库以二进制模式打开文件。
如果不加b,表示默认加了t,即rt,wt,其中t表示以文本模式打开文件。
由fopen()建立的新文件会具有S_IRUSR|S_IWUSR|S_IRGRP|S_IWGRP|S_IROTH|S_IWOTH(0666)权限,此文件权限也会参考umask值。
有些C编译系统可能不完全提供所有这些功能,有的C版本不用"r+","w+","a+",而用"rw","wr","ar"等,读者注意所用系统的规定。
3.二进制文件操作 fread/fwrite
函数原型:
_CRTIMPsize_t __cdecl fread(void *,size_t,size_t,FILE*);
_CRTIMPsize_t __cdecl fwrite(constvoid *,size_t,size_t,FILE*);
当要求一次存取一组数据(如,一个数组、一个结构体变量的值),fread和fwrite函数可以解决该类问题。
它们的调用形式一般为:
fread(buffer,size,count,fp);
fwrite(buffer,size,count,fp);
buffer:
对于fread来说,指的是读入数据的存放地址;对于fwrite来说,是要输出数据的源地址。
size:
读写数据时,每笔数据的大小
count:
读写数据的笔数
fp:
文件指针
2.fclose
函数原型为:
_CRTIMP int__cdecl fclose(FILE*);
关闭成功返回值0,否则返回非零值。
3.字符存取函数fputc/fgetc
函数原型为:
int fputc(int,FILE*);
intfgetc(FILE*);
字符读取函数fgetc()可从文件数据流中一次读取一个字符,然后读取光标移动到下一个字符,并逐步将文件的内容读出。
如果字符读取成功,则返回所读取的字符,否则返回EOF(endoffile)。
EOF是表示数据结尾的常量,真值为-1。
fputc()returnthecharacterwrittenasanunsignedcharcasttoanintorEOFonerror.
2.4字符串存取函数fputs/fgets
函数原型为:
_CRTIMP int__cdecl fputs(constchar *,FILE*);
_CRTIMP char * __cdecl fgets(char *, int,FILE*);
fgets函数的作用是从指定文件读入一个字符串,如:
fgets(str,n,fp);
参数n为要求得到的字符个数,但只从fp指向的文件中读取n-1个字符,然后在最后加一个'\0'字符,因此得到的字符串共有n个字符,把它们放在字符数组str中。
如果在读完n-1个字符之前遇到换行符或EOF,读入结束。
遇到换行符会把’\n’读入然后在末尾加上’\0’;=====”asdfasdf\n\0”
遇到EOF的话直接在末尾加上’\0’;”asdfasdf\0”
fputs函数的作用是向指定文件输出一个字符串,如:
fputs("Hey",fp);
把字符串"Hey"输出到fp指向的文件。
fputs函数的第一个参数可以是字符串常量、字符数组名或字符型指针。
返回值:
若成功,则返回0,否则返回EOF
2.5 格式化存取函数fprintf/fscanf
函数原型为:
_CRTIMP int__cdecl fprintf(FILE*, constchar *,...);
_CRTIMP int__cdecl fscanf(FILE*, constchar *,...);
它们与printf和scanf函数相仿,都是格式化读写函数。
不同的是:
fprintf和fscanf函数的读写对象不是终端(标准输入输出),而是磁盘文件。
printf函数是将内容输出到终端(屏幕),因此,fprintf就是将内容输出到磁盘文件了。
2.6指针重返函数rewind
函数原型为:
_CRTIMP void__cdecl rewind(FILE*);;
rewind函数的作用是使位置指针重返回文件的开头,属于文件的定位。
4.文件结束feof()/EOF
1、feof()函数
另外,要判断文件是否读取完毕,可利用feof()进行检查。
未完返回0,已完返回非零值。
feof()函数原型为:
int feof(FILE*);
2、EOF文件结束符
intc;
while((c=fgetc(fp))!
=EOF)
{
printf("%X/n",c);
}
3.2 随机存取函数fseek()
函数原型:
_CRTIMP int__cdecl fseek(FILE*, long, int);
对流式文件可以进行顺序读写,也可以进行随机读写。
关键在于控制文件的位置指针,如果位置指针是按字节位置顺序移动的,就是顺序读写。
如果能将位置指针按需要移动到任意位置,就可以实现随机读写。
所谓随机读写,是指读完上一个字符(字节)后,并不一定要读写其后续的字符(字节),而可以读写文件中任意位置上所需要的字符(字节)。
该函数的调用形式为:
fseek(fp,offset,start);
start:
起始点。
用0、1、2代替。
0代表文件开始,名字为SEEK_SET,1代表当前位置,名字为SEEK_CUR,2代表文件末尾,名字为SEEK_END。
fseek()函数一般用于二进制文件,因为文本文件要发生字符转换,计算位置时往往会发生混乱。
调用实例如:
fseek(fp,i*sizeof(Person),0);
文件描述符fd-待续
1. open
open:
直接操作物理设备,比如磁盘、设备文件 一般设备/设备文件都通过open来操作
打开设备文件
不带缓冲区
非缓冲文件系统依赖于操作系统,通过操作系统的功能对文件进行读写,是系统级的输入输出,它不设文件结构体指针,只能读写二进制文件,但效率高、速度快
函数原型:
int open(const char *pathname, int flags);
int open(const char *pathname, int flags,mode_tmode);
所需库:
#include #include #include
返回值:
成功则返回文件描述符,否则返回-1;
参数说明:
参数pathname指向欲打开的文件路径字符串.下列是参数flags所能使用的旗标:
O_RDONLY以只读方式打开文件
O_WRONLY以只写方式打开文件
O_RDWR以可读写方式打开文件.上述三种旗标是互斥的,也就是不可同时使用,但可与下列的旗标利用OR(|)运算符组合.
O_CREAT若欲打开的文件不存在则自动建立该文件.
O_EXCL如果O_CREAT也被设置,此指令会去检查文件是否存在.文件若不存在则建立该文件,否则将导致打开文件错误.此外,若O_CREAT与O_EXCL同时设置,并且欲打开的文件为符号连接,则会打开文件失败.
O_NOCTTY如果欲打开的文件为终端机设备时,则不会将该终端机当成进程控制终端机.
O_TRUNC若文件存在并且以可写的方式打开时,此旗标会令文件长度清为0,而原来存于该文件的资料也会消失.
O_APPEND当读写文件时会从文件尾开始移动,也就是所写入的数据会以附加的方式加入到文件后面.
O_NONBLOCK以不可阻断的方式打开文件,也就是无论有无数据读取或等待,都会立即返回进程之中.
O_NDELAY同O_NONBLOCK.
O_SYNC以同步的方式打开文件.
O_NOFOLLOW如果参数pathname所指的文件为一符号连接,则会令打开文件失败.
O_DIRECTORY如果参数pathname所指的文件并非为一目录,则会令打开文件失败。
注:
此为Linux2.2以后特有的旗标,以避免一些系统安全问题.
参数mode则有下列数种组合,只有在建立新文件时才会生效,此外真正建文件时的权限会受到umask值所影响,因此该文件权限应该为(mode-umaks).
S_IRWXU00700权限,代表该文件所有者具有可读、可写及可执行的权限.
S_IRUSR或S_IREAD,00400权限,代表该文件所有者具有可读取的权限.
S_IWUSR或S_IWRITE,00200权限,代表该文件所有者具有可写入的权限.
S_IXUSR或S_IEXEC,00100权限,代表该文件所有者具有可执行的权限.
S_IRWXG00070权限,代表该文件用户组具有可读、可写及可执行的权限.
S_IRGRP00040权限,代表该文件用户组具有可读的权限.
S_IWGRP00020权限,代表该文件用户组具有可写入的权限.
S_IXGRP00010权限,代表该文件用户组具有可执行的权限.
S_IRWXO00007权限,代表其他用户具有可读、可写及可执行的权限.
S_IROTH00004权限,代表其他用户具有可读的权限
S_IWOTH00002权限,代表其他用户具有可写入的权限.
S_IXOTH00001权限,代表其他用户具有可执行的权限.
返回值:
若所有欲核查的权限都通过了检查则返回0值,表示成功,只要有一个权限被禁止则返回-1.
错误代码:
EEXIST参数pathname所指的文件已存在,却使用了O_CREAT和O_EXCL旗标.
EACCESS参数pathname所指的文件不符合所要求测试的权限.
EROFS欲测试写入权限的文件存在于只读文件系统内.
EFAULT参数pathname指针超出可存取内存空间.
EINVAL参数mode不正确.
ENAMETOOLONG参数pathname太长.
ENOTDIR参数pathname不是目录.
ENOMEM核心内存不足.
ELOOP参数pathname有过多符号连接问题.
EIOI/O存取错误.
附加说明:
使用access()作用户认证方面的判断要特别小心,例如在access()后再作open()空文件可能会造成系统安全上的问题.
write
头文件:
#include
定义函数:
ssize_twrite(intfd,constvoid*buf,size_tcount);
函数说明:
write()会把参数buf所指的内存写入count个字节到参数fd所指的文件内.当然,文件读写位置也会随之移动.
返回值:
如果顺利write()会返回实际写入的字节数.当有错误发生时则返回-1,错误代码存入errno中.
s错误代码:
EINTR此调用被信号所中断.
EAGAIN当使用不可阻断I/O时(O_NONBLOCK),若无数据可读取则返回此值.
EADF参数fd非有效的文件描述词,或该文件已关闭.
1.popen
popen:
会调用fork()产生子进程,然后从子进程中调用/bin/sh -c来执行参数command的指令 依照popen参数中的type值建立管道连接到子进程的输入/输出设备中,通过返回的指针对子进程 的输入、输出设备进行操作。
打开管道
函数原型:
FILE *popen( const char *command, const char *type);
所需库:
返回值:
如果调用fork()或pipe()失败,或者不能分配内存将返回NULL,否则返回标准I/O流。
功能:
创建一个管道,fork一个子进程,接着关闭管道的不使用端,子进程执行cmd指向的应用程序或者命令。
执行完该函数后父进程和子进程之间生成一条管道,函数返回值为FILE结构指针,该指针作为管道的一端,为父进程所拥有。
子进程则拥有管道的另一端,该端口为子进程的stdin或者stdout。
如果type=r,那么该管道的方向为:
子进程的stdout到父进程的FILE指针;如果type=w,那么管道的方向为:
父进程的FILE指针到子进程的stdin。
参数说明:
type 参数只能是读或者写中的一种,得到的返回值(标准I/O流)也具有和type相应的只读或只写类型。
如果type是"r"则文件指针连接到command的标准输出;如果type是"w"则文件指针连接到command的标准输入。
command 参数是一个指向以NULL结束的shell命令字符串的指针。
这行命令将被传到bin/sh并使用-c标志,shell将执行这个命令。
文件偏移量操作
1.lseek
所有打开的文件都有一个当前文件偏移量