fopen s函数的用法,fopen 用法
fopen s函数的用法,fopen 用法详细介绍
本文目录一览: vs中,fopen_s函数怎么用,能不能举个例子?
#include
main()
{
FILE* fpout;
char ch;
if((fpout=fopen("file_a.dat","r"))==NULL)
{
printf("can't open this file!\n"); exit(0);
}
ch = fgetc(fpout);
while(ch!=EOF)
{
putchar(ch); ch = fgetc(fpout);
}
fclose(fpout);
}
使用方法:
首先看fopen的代码:
FILE* fp = null;fp = fopen(filename,"w+")if(fp!=null){// 打开文件成功}再来看fopen_s的用法
FILE* fp = null;errno_t err = 0;err = fopen_s(&fp,filename,"w+")if(err==0){// 打开文件成功}
fopen函数的用法
php fopen函数用法如下:
fopen作用:打开文件或者URL。
语法:fopen(filename,mode,include_path,context)
fopen()会获取文件信息,包括文件名、文件状态、当前读写位置等,并将这些信息保存到一个FILE类型的结构体变量中,然后将该变量的地址返回。FILE是
头文件中的一个结构体,它专门用来保存文件信息。我们不用关心FILE的具体结构,只需要知道它的用法就行。
如果希望接收fopen()的返回值,就需要定义一个FILE类型的指针。不同的操作需要不同的文件权限。例如,只想读取文件中的数据的话,“只读”权限就够了;既想读取又想写入数据的话,“读写”权限就是必须的了。
另外,文件也有不同的类型,按照数据的存储方式可以分为二进制文件和文本文件,它们的操作细节是不同的。在调用fopen()函数时,这些信息都必须提供,称为“文件打开方式”。
fopen 用法
fopen()函数的用法:
fopen函数用于打开文件, 其调用格式为:FILE *fopen(char *filename, *type);fopen()函数中第一个形式参数表示文件名, 可以包含路径和文件名两部分。如:"B:TEST.DAT""C:\\TC\\TEST.DAT"注意:如果将路径写成"C:\TC\TEST.DAT"是不正确的, 这一点要特别注意。
fopen函数用来打开一个文件,其调用的一般形式为:?文件指针名=fopen(文件名,使用文件方式)
其中,“文件指针名”必须是被说明为FILE?类型的指针变量,“文件名”是被打开文件的文件名。
“使用文件方式”是指文件的类型和操作要求。“文件名”是字符串常量或字符串数组。例如:
FILE?*fp;
fp=("file_a","r");
其意义是在当前目录下打开文件file_ a,?只允许进行“读”操作,并使fp指向该文件。
又如:
FILE?*fphzk
fphzk=("c:\\hzk16',"rb")
其意义是打开C驱动器磁盘的根目录下的文件hzk16,?这是一个二进制文件,只允许按二进制方式进行读操作。
两个反斜线“\\?”中的第一个表示转义字符,第二个表示根目录。使用文件的方式共有12种,下面给出了它们的符号和意义。
第二个形式参数表示打开文件的类型。关于文件类型的规定参见下表。
字符 含义
? ────────────────────────────??????????
"r"??????????? 打开文字文件只读??????????
"w"?????????? 创建文字文件只写?????????
"a"?????????? 增补, 如果文件不存在则创建一个?????
"r+"????????? 打开一个文字文件读/写????????
"w+"???????? 创建一个文字文件读/写??????????
"a+"???????? 打开或创建一个文件增补??????????
"b"?????????? 二进制文件(可以和上面每一项合用)??????????
"t"?????????? 文这文件(默认项)??
━━━━━━━━━━━━━━━━━━━━━━━━━━━━
文件使用方式? 意?义
“rt” 只读打开一个文本文件,只允许读数据
“wt” 只写打开或建立一个文本文件,只允许写数据
“at” 追加打开一个文本文件,并在文件末尾写数据
“rb” 只读打开一个二进制文件,只允许读数据
“wb” ? ?只写打开或建立一个二进制文件,只允许写数据
“ab”? ? 追加打开一个二进制文件,并在文件末尾写数据
“rt+” ?读写打开一个文本文件,允许读和写
“wt+” ?读写打开或建立一个文本文件,允许读写
“at+” ?读写打开一个文本文件,允许读,或在文件末追加数?据
“rb+” ?读写打开一个二进制文件,允许读和写
“wb+” ?读写打开或建立一个二进制文件,允许读和写
“ab+”? 读写打开一个二进制文件,允许读,或在文件末追加数据
对于文件使用方式有以下几点说明:
1.?文件使用方式由r,w,a,t,b,+六个字符拼成,各字符的含义是:
r(read):?读
w(write):?写
a(append):?追加
t(text):?文本文件,可省略不写
b(banary):?二进制文件
+:?读和写
2.?凡用“r”打开一个文件时,该文件必须已经存在,?且只能从该文件读出。
3.?用“w”打开的文件只能向该文件写入。?若打开的文件不存在,则以指定的文件名建立该文件,若打开的文件已经存在,则将该文件删去,重建一个新文件。
4.?若要向一个已存在的文件追加新的信息,只能用“a?”方式打开文件。
5.?在打开一个文件时,如果出错,fopen将返回一个空指针值NULL。在程序中可以用这一信息来判别是否完成打开文件的工作,并作相应的处理。因此常用以下程序段打开文件:
if((fp=fopen("c:\\hzk16","rb")==NULL)
{
printf("\nerror?on?open?c:\\hzk16?file!");
getch();
exit(1);
}
这段程序的意义是,如果返回的指针为空,表示不能打开C盘根目录下的hzk16文件,则给出提示信息“error?on?open?c:\?hzk16file!”,下一行getch()的功能是从键盘输入一个字符,但不在屏幕上显示。在这里,该行的作用是等待,?只有当用户从键盘敲任一键时,程序才继续执行,?因此用户可利用这个等待时间阅读出错提示。敲键后执行exit(1)退出程序。
6.?把一个文本文件读入内存时,要将ASCII码转换成二进制码,?而把文件以文本方式写入磁盘时,也要把二进制码转换成ASCII码,因此文本文件的读写要花费较多的转换时间。对二进制文件的读写不存在这种转换。
7.?标准输入文件(键盘),标准输出文件(显示器?),标准出错输出(出错信息)是由系统打开的,可直接使用。文件关闭函数fclose文件一旦使用完毕,应用关闭文件函数把文件关闭,?以避免文件的数据丢失等错误。
如果要打开一个CCDOS子目录中, 文件名为CLIB的二进制文件, 可写成:fopen("c:\\ccdos\\clib", "rb");如果成功的打开一个文件, fopen()函数返回文件指针,?? 否则返回空指针(NULL)。由此可判断文件打开是否成功。2. fclose()函数?? fclose()函数用来关闭一个由fopen()函数打开的文件 , 其调用格式为:?? nt fclose(FILE *stream);?? 该函数返回一个整型数。当文件关闭成功时, 返回0, 否则返回一个非零值。可以根据函数的返回值判断文件是否关闭成功。 例子:FILE *fpOut=fopen(“c:\\a.txt”,”wt+”);Int a=1;Fprintf(fpOut,”%d”,a);Fclose(fpOut);
求问用VC编译C语言程序中fopen_s的具体使用方式
fopen_s函数的话:
FILE* f;fopen_s(&f,"
","w");即可。
文件名.txt>
linux编程,用fopen_s函数的方法
linux 下,直接使用fopen, 比如
FILE* p_file = fopen("a.txt", "a+b");
据我说知,fopen_s是WINDOWS 下广泛用的,window下任务printf,fopen, scanf 等不安全,在后面加了个_S,
怎么在gcc中使用fopen_s?
如果你有读过 C语言标准的话,C 语言有三个比较大的版本 C89/99/11
fopen_s 是属于 C11 的新内容,首先要你的编译器支持 C11
【编译器是否支持C11】
这个可以通过预定义宏(__STDC_VERSION__)判断,也就是
#if __STDC_VERSION__ >= 201112L
或者 if(__STDC_VERSION__ >= 201112L)
如果是支持 C11 的编译器会返回 true
【编译器是否支持 Annex K】
然后在支持 C11 条件下,编译器可以选择是否支持 Annex K ( 附录K )
( 支持附录K,意味着支持 fopen_s 这些函数 )
判断编译器是否支持 Annex K,只需要判断预定义宏(__STDC_LIB_EXT1__),也就是
#if __STDC_LIB_EXT1__ >= 201112L
或者 if(__STDC_LIB_EXT1__ >= 201112L)
如果是支持 Annex K 的编译器会返回 true
【向编译器请求启用 Annex K 下的安全函数使用】
#define __STDC_WANT_LIB_EXT1__ 1
#include
在导入
之前,定义宏 __STDC_WANT_LIB_EXT1__ 的值为 1
恭喜你启用了 printf_s scanf_s fopen_s 这些安全函数
【此方法不一定都适用】
这个方法仅适用于那些按照C语言标准的编译器,mingw64编译器我没用过,
只知道像 vs 就默认启用 scanf_s,如果以上方法不行,具体编译器要查具体规则
c++中fopen函数读文件怎么用文件数据?
本文分别简单讲述了如何利用C和C++库函数对文件的读写,涵盖了常用的文件操作函数。网上关于C/C++文件操作的介绍的博客很多,所以本文也大同小异,也主要是做一个备忘,不有每次都百度了。但本文重点在于几个库函数的运用,而不是从文件的属性或分类开始。\x0d\x0a一、C文件操作:\x0d\x0a C语言中,文件的操作都是通过一个FILE类型的文件指针进行,也就是说只有通过文件指针,才能调用相应的文件。FILE是一个由系统定义的结构体(定义在stdio.h中),可以存放文件的相关信息。\x0d\x0a文件的打开(fopen函数)\x0d\x0a 文件的操作过程一般为:打开 => 读/写 => 关闭。\x0d\x0afopen函数的原型如下:\x0d\x0a FILE* fopen(const char* filename, const char* mode); \x0d\x0a函数调用就比较简单了:\x0d\x0a FILE* fp;\x0d\x0a fp = fopen("file1.txt", "r");\x0d\x0a如果打开成功,返回file1.txt文件的指针,如果打开失败,返回一个NULL指针,所以调用fopen()后我们需要检查fp的值才进行下一步操作。fopen()的第一个参数为文件名,第二个参数为文件打开方式,含义如下表:\x0d\x0a说明: 1. 使用"r"时,如果文件不存在,则出错。\x0d\x0a 2. 使用"w"时,如果没有文件,则创建一个新文件。\x0d\x0a 3. 使用"a"时,如果希望向文件尾添加数据,则该文件必须存在,否则出错。\x0d\x0a 4. "r+","w+","a+"都是可以输入和输出数据,但必须遵守上述3点\x0d\x0a 5. 操作二进制文件时,加上"b"字符,且二进制文件对换行符不会进行转换,而文本文件会将换行符转换为回车和换行两个字符。\x0d\x0a文件的关闭(fclose函数)\x0d\x0a 在使用完一个文件后,若不关闭则会造成系统资源泄漏。使用fclose()关闭文件即可,原型为 int fclose(FILE* fp)。使用:fclose(fp); flose()返回0时为顺利关闭文件,否则返回EOF(-1)。\x0d\x0a文件的读写\x0d\x0a 1) fputc(), fgetc()分别为从文件流中写和读一个字符,原型分别如下:\x0d\x0a 写:int fputc(int c, FILE* fp); 读:int fgetc(FILE* fp); 失败时均返回EOF\x0d\x0a 2) fputs(), fgets()分别为从文件流中写和读一个字符串,原型分别如下:\x0d\x0a 写:int fputs(const char* str, FILE* fp); 例如: fputs("I love this game!", fp);\x0d\x0a 读:char* fgets(char* str, int n, FILE* fp); 从流中读取n-1个字符或读完一行,参数str用于接收读取的字符串。注意当读取一行时,不包括行尾的'\n'字符。\x0d\x0a 3) fseek() 一般用于二进制模式打开的文件中,功能是定位到流中指定的位置。原型如下:\x0d\x0a int fseek(FILE* fp, lont offset, int whence); 参数offset是移动的字符数,whence是移动的基准,取值是:\x0d\x0a SEEK_SET 0 //文件开头 \x0d\x0a SEEK_CUR 1 //当前读写的位置 \x0d\x0a SEEK_END 2 //文件尾部 \x0d\x0a 4) fprintf(),fscanf()是将数据按格式输出输入到文件流中,用法类似printf()和scanf()。原型分别如下:\x0d\x0a int fprintf(FILE* fp, const char* format, ...); 它与printf()不同的就是将数据写到了文件流中,而不是控制台罢了。\x0d\x0a int fscanf(FILE* fp, cosnt char* format, ...); 从文件流中按格式读取,与scanf()不同的就是数据是从文件流中读取而已。\x0d\x0a 例如: fprintf(fp, "count=%d", 5); fscanf(fp, "%d", &x);\x0d\x0a 5) feof()是检测是否已到文件尾,是返回真,否则返回0,原型是 int feof(FILE* fp);\x0d\x0a 6) rewind() 则是把当前的读写位置回到文件开始,相当于 fseek(fp, 0L, SEEK_SET); 原型: void rewind(FILE* fp);\x0d\x0a 7) remove() 删除文件,原型: int remove(const char* filename); 参数为要删除的文件名,成功则返回0;\x0d\x0a 8) fread(), fwrite() 它们相当于可将一块的数据读出或写入,相当的方便。原型如下:\x0d\x0a size_t fread(void* ptr, size_t size, size_t n, FILE* fp); 从流中读指定个数的字符,size是每块的字节娄,n则是读取的块数。\x0d\x0a size_t fwrite(const void* ptr, size_t size, size_t n, FILE* fp); 类似的是向文件流中写入n块size字节数的数据。可以看到数据指针为void*型,即可以使用任何类型的指针来替换。例如:\x0d\x0a现在一个结构体: struct student_t{char name[16]; int id; int age;}; 创建三个学生的数据并赋值:struct student_t stu[3];\x0d\x0a这时,当我们找开文件后(一般是进制模式),可以调用fwrite()将三个学生的数据都写入到文件中,两种方式:\x0d\x0a for(int i = 0; i < 3; ++i)\x0d\x0a fwrite(&stu[i], sizeof(struct student_t), 1, fp); \x0d\x0a 或者:fwrite(stu, sizeof(struct student_t), 3, fp);\x0d\x0a些时,我们调用fread()函数便可很轻松的将刚才写入的3个学生的数据读取出来:\x0d\x0a struct student_t stus[3];\x0d\x0a for(int i = 0; i < 3; ++i)\x0d\x0a fread(&stus[i], sizeof(struct student_t), 1, fp);\x0d\x0a 或者:fread(stus, sizeof(struct student_t), 3, fp); 这样便可将三个学生的数据读入到stus变量中了(有木有很方便呐)\x0d\x0a注意:如果你发现使用fread()读取之后,最后一个学生读取的数据不完全,可能是由于你没有使用二进制模式打开的原因。\x0d\x0a 9) 最后是tmpfile()和tmpnam(),前者为生成一个临时文件,后者为生成一个唯一的文件名,具体使用在此不介绍了。\x0d\x0a二、使用C++中的fstream文件流操作类进行文件的读写\x0d\x0a 使用fstream操作文件与使用C库函数类似,只不过fstream为面向对象方式,或多了上些C++的特性。首先,这里大概有三个流:\x0d\x0afstream为文件输入输出流,ifstream为输入文件流,ofstream为输出文件流,它们与ostream不同的就流的目的地为文件,而不是控制台。这里只介绍与上述的一些不同点:\x0d\x0a 1. 打开文件,如可以是 ifstream input_file("file2.txt"); 这样将会以默认方式打开file2.txt文件并进行读取。也可使用open()方式打开一个文件,并指定打开方式,例如:\x0d\x0a ifstream input_file;\x0d\x0a input_file.open("file2.txt", ios::binary); \x0d\x0a打开后,可以使用is_open()检测是否打开成功:\x0d\x0a if(input_file.is_open()){},然后可以使用流操作符向文件写数据了,例如:\x0d\x0a input_file << "this is a test line";\x0d\x0a input_file << "another info";\x0d\x0a另外,这里的文件打开方式在ios空间下:\x0d\x0a ios::app 添加到文件尾\x0d\x0a ios::ate 把文件标志放在末尾而非起始。\x0d\x0a ios::trunc 默认. 截断并覆写文件。\x0d\x0a ios::nocreate 文件不存在也不创建。\x0d\x0a ios::noreplace 文件存在则失败。\x0d\x0aofstream使用方式类似,读取一行数据可以使用getline(buf, count), 类型于fgets()。fstream类还提供一个很多其它方法,如fclose()为关闭文件,eof()用于检测状态是否已经到了文件末尾。\x0d\x0a这里还有两个类似于上述的fread()和fwrite()函数,是read(), write(),功能和用法类似类似,例如:\x0d\x0a output_file.write((const char*)stu, 3 * sizeof(struct student_t));\x0d\x0a input_file.read((char*)stus, 3 * sizeof(struct student_t));\x0d\x0a注意,这里也需要使用二进制模式打开,否则read的时候最后的上些数据读不完全。调用上面两个函数后可以使用bad()来检测文件流对象是否错误,例如,if(input_file.bad()){printf("error when read file\n"); return;},最后input_file.close()即可。\x0d\x0a 最后,C/C++文件的操作并不复杂,多使用几次便可熟练掌握,需要注意的就是文件的打开方式,和当用同一个文件指针进行又读又写时,注意文件指针位置的移动。
fopen函数用法
fopen("...","...")
第一个参数是指向一个文件,如果当前文件不存在,系统会创建这个文件名。第二个参数是对这个文件进行的操作。例如,只读,读写,写等。
请参看下面的程序,了解其具体用法。下面程序实现的是在zhubihui.txt中写入创建子程序的结果。
#include
#include
#include
main()
{
int p1,p2,i;
FILE *fp;
fp=fopen("zhubihui.txt","w+");
if(fp==NULL)
{printf("Fail to create file");
exit(-1);
}
while((p1=fork())==-1);
if(p1==0)
{lockf((int)fp,1,0);
for(i=0;i<10;i++)
fprintf(fp,"daughter%d\n",i);
lockf((int)fp,0,0);
}
else
{while((p2=fork())==-1);
if(p2==0)
{lockf((int)fp,1,0);
for(i=0;i<10;i++)
fprintf(fp,"son%d\n",i);
lockf((int)fp,0,0);
}
else
{
wait(NULL);
lockf((int)fp,1,0);
for(i=0;i<10;i++)
fprintf(fp,"parent%d\n",i);
lockf((int)fp,0,0);
}
}
fclose(fp);
}
fopen("……","r");
C语言中的fopen函数的具体实现是怎么样?
lib库,没得源代码,很可能是汇编的代码。
fopen(a,b),意思是打开一个文件名字为a的文件
fopen_s的函数备注
通过打开的文件fopen_s和_wfopen_s不是可共享。如果您需要先设置为可共享一个文件,则使用_fsopen、_wfsopen与适当的共享模式常量 — — 例如,_SH_DENYNO为读/写的共享。fopen_s函数打开的文件指定的filename._wfopen_s是宽字符版本的fopen_s; 参数与_wfopen_s是宽字符字符串。_wfopen_s和fopen_s的行为相同 ; 否则。fopen_s可以接受的有效执行 ; 在文件系统上的路径 UNC 路径和涉及到映射的网络驱动器的路径所接受的fopen_s,只要正在执行代码的系统有权访问该共享,或在执行时映射的网络驱动器。当构造路径fopen_s、 不要臆测可用性驱动器、 路径或网络共享的执行环境中。您可以使用正斜杠 (/) 或反斜杠 (\),作为路径中的目录分隔符。这些函数将验证它们的参数。如果pFile,filename,或mode为 null 的指针,这些函数生成无效参数异常,如中所述参数验证.检查返回值,是否函数成功执行该文件的任何进一步操作之前,请参阅。如果发生错误,则返回的错误代码和全局变量errno设置。有关详细信息,请参阅errno、_doserrno、_sys_errlist 和 _sys_nerr.