C/C++ 中fopen_s与fopen
2016-07-23 10:27
295 查看
fopen函数[/b]
fopen("文件名","打开方式")、FILE *fopen( const char
*filename, const char *mode );
r 打开只读文件,该文件必须存在。r+ 打开可读写的文件,该文件必须存在。rb+
读写打开一个二进制文件,只允许读写数据。rt+ 读写打开一个文本文件,允许读和写。
w
打开只写文件,若文件存在则文件长度清为0,即该文件内容会消失。若文件不存在则建立该文件。w+
打开可读写文件,若文件存在则文件长度清为零,即该文件内容会消失。若文件不存在则建立该文件。
a
以附加的方式打开只写文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾,即文件原先的内容会被保留。(EOF符保留)
a+
以附加方式打开可读写的文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾后,即文件原先的内容会被保留。(原来的EOF符不保留)
wb 只写打开或新建一个二进制文件;只允许写数据。 wb+
读写打开或建立一个二进制文件,允许读和写。 wt+ 读写打开或着建立一个文本文件;允许读写。
at+ 读写打开一个文本文件,允许读或在文本末追加数据。
ab+ 读写打开一个二进制文件,允许读或在文件末追加数据。
fopen_s函数:fopen_s比fopen多了溢出检测,更安全一些。[/b]
fopen_s(地址指针,"文件地址","打开方式")
例如fopen_s(&id,"test.txt","r");读取test并让id指针指向这个文件。
打开方式同fopen。
———————————————————————————————————
问题:vs2005中编程时,遇到如下: warning C4996:
“fopen”被声明为否决的
解释:微软的警告,主要是那些都是C库的函数,很多函数内部是不进行参数检测的(包括越界类的),微软担心使用这些会造成内存异常,所以就改写了一下同样功能的函数,只不过进行了参数的检测,使用这些新的就可以了。不用特意记,每个函数在给出警告时都会告诉你相应的安全函数,注意一下警告信息就可以了,使用时再
查看一下MSDN。库函数改写例子:
mkdir改写为 _mkdir
fopen”改写为
fopen_s
stricmp改写为
stricmp_s
解决:
1> 根据下面的warning提示:参见“fopen”的声明消息:“This function or variable may be unsafe.
Consider using fopen_s instead. To disable deprecation, use
_CRT_SECURE_NO_DEPRECATE. See online help for
details.”
所以可以将函数按warning提示的第二句使用fopen_s函数即可:
eg:FILE *pFile=fopen("1.txt", "w");
改为:
FILE*
pFile;
fopen_s(&pFile, "1.txt", "w");
2> 还是根据warning提示的地三句话:use
_CRT_SECURE_NO_DEPRECATE项目|属性|配置属性|C/C++|命令行|附加选项,加入【/D "_CRT_SECURE_NO_DEPRECATE"
】(注:加入中括号中完整的内容)
3> 降低警告级别:项目|属性|配置属性|C/C++|常规,自己根据情况降低警告级别(此法不推荐)
注:高度重视警告:使用编译器的最高警告级别。应该要求构建是干净利落的(没有警告)。理解所有警告。通过
修改代码而不是降低警告级别来排除警告。
编译器是你的朋友。如果它对某个构造发出警告,这经常是说明你的代码中存在潜在的问题。成功的构建应该是无声无息的(没有警告的)
fopen("文件名","打开方式")、FILE *fopen( const char
*filename, const char *mode );
r 打开只读文件,该文件必须存在。r+ 打开可读写的文件,该文件必须存在。rb+
读写打开一个二进制文件,只允许读写数据。rt+ 读写打开一个文本文件,允许读和写。
w
打开只写文件,若文件存在则文件长度清为0,即该文件内容会消失。若文件不存在则建立该文件。w+
打开可读写文件,若文件存在则文件长度清为零,即该文件内容会消失。若文件不存在则建立该文件。
a
以附加的方式打开只写文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾,即文件原先的内容会被保留。(EOF符保留)
a+
以附加方式打开可读写的文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾后,即文件原先的内容会被保留。(原来的EOF符不保留)
wb 只写打开或新建一个二进制文件;只允许写数据。 wb+
读写打开或建立一个二进制文件,允许读和写。 wt+ 读写打开或着建立一个文本文件;允许读写。
at+ 读写打开一个文本文件,允许读或在文本末追加数据。
ab+ 读写打开一个二进制文件,允许读或在文件末追加数据。
fopen_s函数:fopen_s比fopen多了溢出检测,更安全一些。[/b]
fopen_s(地址指针,"文件地址","打开方式")
例如fopen_s(&id,"test.txt","r");读取test并让id指针指向这个文件。
打开方式同fopen。
———————————————————————————————————
问题:vs2005中编程时,遇到如下: warning C4996:
“fopen”被声明为否决的
解释:微软的警告,主要是那些都是C库的函数,很多函数内部是不进行参数检测的(包括越界类的),微软担心使用这些会造成内存异常,所以就改写了一下同样功能的函数,只不过进行了参数的检测,使用这些新的就可以了。不用特意记,每个函数在给出警告时都会告诉你相应的安全函数,注意一下警告信息就可以了,使用时再
查看一下MSDN。库函数改写例子:
mkdir改写为 _mkdir
fopen”改写为
fopen_s
stricmp改写为
stricmp_s
解决:
1> 根据下面的warning提示:参见“fopen”的声明消息:“This function or variable may be unsafe.
Consider using fopen_s instead. To disable deprecation, use
_CRT_SECURE_NO_DEPRECATE. See online help for
details.”
所以可以将函数按warning提示的第二句使用fopen_s函数即可:
eg:FILE *pFile=fopen("1.txt", "w");
改为:
FILE*
pFile;
fopen_s(&pFile, "1.txt", "w");
2> 还是根据warning提示的地三句话:use
_CRT_SECURE_NO_DEPRECATE项目|属性|配置属性|C/C++|命令行|附加选项,加入【/D "_CRT_SECURE_NO_DEPRECATE"
】(注:加入中括号中完整的内容)
3> 降低警告级别:项目|属性|配置属性|C/C++|常规,自己根据情况降低警告级别(此法不推荐)
注:高度重视警告:使用编译器的最高警告级别。应该要求构建是干净利落的(没有警告)。理解所有警告。通过
修改代码而不是降低警告级别来排除警告。
编译器是你的朋友。如果它对某个构造发出警告,这经常是说明你的代码中存在潜在的问题。成功的构建应该是无声无息的(没有警告的)
相关文章推荐
- NYOJ 23取石子问题(巴什博弈)
- C++ virtual函数 实现机制
- C++、Visual C++、MFC(编译和封装)之间的关系是什么?
- 使用QProxyStyle定制QMenu (二)
- sprintf和sscanf的用法
- C++软件添加dump调试打印日志(推荐)
- C语言实现ping功能(查看设备联网状态)
- C语言中字符串的赋值
- C++重载函数 const形参 引用指针 const_cast
- 继承
- 【C++11】C++11新增的便利算法[1] all_of、any_of 和 none_of
- 李洪强漫谈iOS开发[C语言-017]-printf函数
- c语言程序结构,全局变量,局部变量
- 李洪强漫谈iOS开发[C语言-016]-变量的作用域
- C语言学习-结构体
- 李洪强漫谈iOS开发[C语言-015]-变量的使用
- C语言基础知识
- 合并两个排序的链表 C++
- VC封装Ping命令的实现
- C++修炼之路 map