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的值转化为有意义的字符输出。

 

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值