本文主要是介绍itoa或者_itoa_s,fopen 和 fopen_s等几种函数的用法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
1 itoa或者_itoa_s的用法
itoa这几个函数都被ISO标准取消了,至少不推荐。用 sprintf(s,"%d",i) 代替,
把 int i “打印” 到 char s[20]中;这种对字符串的打印,代替了itoa的危险转化。
补充,以下是标准C99的做法。
errno_t _itoa_s(
int value, //要转换的数字
char *buffer, //存放转换结果的字符串
size_t sizeInCharacters, //存放结果的字符数组长度
int radix //转化的进制数,2表示2进制,10表示10进制
);
还有一个类似的函数 *itoa,它与_itoa_s不同之处在于少一个参数;
char *itoa( int value, char *buffer, int radix);
*itoa() 函数有3个参数:第一个参数是要转换的数字,第二个参数是要写入转换结果的目标字符串,第三个参数是转移数字时所用的基数。
简而言之,_itoa_s是将整数转换成字符串的函数, 如果是C++,更不能用itoa这种毒药。
直接对<sstream> stringstream s;
s<<i; //直接对字符流(或任何输入流)输入整型 i,才是c++的地道做法。
itoa并不是一个标准的C函数,它是Windows特有的,如果要写跨平台的程序,请用sprintf。
2 fopen 和 fopen_s
fopen用法: fp = fopen(filename,"w")。
fopen_s用法: 须定义另外一个变量errno_t err,然后err = fopen_s(&fp,filename,"w")。
返回值: fopen打开文件成功,返回文件指针(赋值给fp),打开失败则返回NULL值;
fopen_s打开文件成功返回0,失败返回非0。
在定义FILE * fp 之后,fopen的用法是: fp = fopen(filename,"w")。而对于fopen_s来说,还得定义另外一个变量errno_t err,然后err = fopen_s(&fp,filename,"w")。返回值的话,对于fopen来说,打开文件成功的话返回文件指针(赋值给fp),打开失败则返回NULL值;对于fopen_s来说,打开文件成功返回0,失败返回非0。
在vs编程中,经常会有这样的警告:warning C4996: 'fopen': This function or variable may be unsafe. Consider using fopen_s instead. To disable deprecation, use_CRT_SECURE_NO_WARNINGS. See online help for details. 是因为 fopen_s比fopen多了溢出检测,更安全一些。(在以后的文章里还有get与get_s的比较,strcpy strcpy_s的比较,他们的共同点都是用来一些不可预料的行为,以后将进行详尽解释)
#include
FILE *stream, *stream2;
int main( void )
{
int numclosed;
errno_t err;
// Open for read (will fail if file "crt_fopen_s.c" does not exist)
if( (err = fopen_s( &stream, "crt_fopen_s.c", "r" )) !=0 )
printf( "The file 'crt_fopen_s.c' was not opened\n" );
else
printf( "The file 'crt_fopen_s.c' was opened\n" );
// Open for write
if( (err = fopen_s( &stream2, "data2", "w+" )) != 0 )
printf( "The file 'data2' was not opened\n" );
else
printf( "The file 'data2' was opened\n" );
// Close stream if it is not NULL
if( stream)
{
if ( fclose( stream ) )
{
printf( "The file 'crt_fopen_s.c' was not closed\n" );
}
}
// All other files are closed:
numclosed = _fcloseall( );
printf( "Number of files closed by _fcloseall: %u\n", numclosed );
}
3 access或者_access的用法
在Linux下,access函数的声明在<unistd.h>文件中,声明如下:
int access(const char *pathname, int mode);
access函数用来判断指定的文件或目录是否存在(F_OK),已存在的文件或目录是否有可读(R_OK)、可写(W_OK)、可执行(X_OK)权限。F_OK、R_OK、W_OK、X_OK这四种方式通过access函数中的第二个参数mode指定。如果指定的方式有效,则此函数返回0,否则返回-1。
在Windows下没有access函数,但在Windows 的<io.h>文件中有_access函数,声明如下:
int _access(const char * _Filename, int Accessmode);
windows下的函数_access与linux下的access函数功能类似,用来判断指定的文件或目录是否仅存在(00),已存在的文件或目录是否有仅读(04)、仅写(02)、既可读又可写(06)权限。这四种方式通过_access函数中的第二个参数mode指定,如果mode传入的值不是0或2或4或6,调用此函数则会crash。如果指定的方式有效,则此函数返回0,否则返回-1。
备注:当pathname为文件时,_access函数判断文件是否存在,并判断文件是否可以用mode值指定的模式进行访问。当pathname为目录时,_access只判断指定目录是否存在,在Windows NT和Windows 2000中,所有的目录都只有读写权限。
mode的值和含义如下所示:
00——只检查文件是否存在
02——写权限
04——读权限
06——读写权限
对应的还有_access的宽字符版本,用法相同。
4 linux中的errno_t没有定义错误
做IO操作时,常常会得到一个errno_t,其实就是整数 typedef int errno_t;
是VC的errno头文件,errno.h。linux中找不到这个文件,在windows中可以找到。
errno_t是一种数据类型,实际上是一个整形,代表错误号码。
比如0就代表没有错误,1就找不到文件等。linux 中用法不一样,errno是一个包含在<errno.h>中的预定义的外部int变量,用于表示最近一个函数调用是否产生了错误。若为0,则无错误,其它值均表示一类错误。
perror()和strerrot()函数可以把errno的值转化为有意义的字符输出。
这篇关于itoa或者_itoa_s,fopen 和 fopen_s等几种函数的用法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!