CRT函数解读

C Runtime是windows平台下的一个概念。一般来说,CRT函数就是标准的C语言函数。例如,printf、scanf、strlen、fopen等函数就属于CRT函数。
在windows下所有的CRT函数最终都是转化成为win32 API来执行的。windows本身并没有在内核之上提供对CRT的支持。 CRT既可以通过静态连接来实现,也可以通过动态链接来实现(MSVCRT.DLL)。
 
 
 

常用的安全CRT函数 安全CRT(C Runtime Library = C运行时间库)函数,是微软公司对C/C++语言的扩展。它在原来函数名后添加了“_s”后缀;一般返回出错代码;并将原来的函数返回值,作为一个参数,添加到函数输入参数列表的最后;对带缓冲区参数的函数,还添加了表示缓冲区大小的输入参数,以防止内存溢出。 在VC05中,如果不使用这些安全性函数,编译器会报告警告性错误。 下面是若干常用的安全CRT函数: char *gets_s( char *buffer, size_t sizeInCharacters); // <stdio.h> wchar_t *_getws_s( wchar_t *buffer, size_t sizeInCharacters); // <stdio.h> or <wchar.h> errno_t _itoa_s( int value, char *buffer, size_t sizeInCharacters, int radix ); // <stdlib.h> errno_t _itow_s( int value, wchar_t *buffer, size_t sizeInCharacters, int radix ); // <stdlib.h> errno_t _ultoa_s( unsigned long value, char *str, size_t sizeOfstr, int radix ); // <stdlib.h> errno_t _ultow_s( unsigned long value, wchar_t *str, size_t sizeOfstr, int radix ); // <stdlib.h> int printf_s( const char *format [, argument]... ); // <stdio.h> int wprintf_s( const wchar_t *format [, argument]... ); // <stdio.h> or <wchar.h> int scanf_s( const char *format [, argument]... ); // <stdio.h> int wscanf_s( const wchar_t *format [, argument]... ); // <stdio.h> or <wchar.h> int sprintf_s( char *buffer, size_t sizeOfBuffer, const char *format [, argument] ... ); // <stdio.h> int swprintf_s( wchar_t *buffer, size_t sizeOfBuffer, const wchar_t *format [, argument]...); // <stdio.h> or <wchar.h> int sscanf_s( const char *buffer, const char *format [, argument ] ...); // <stdio.h> int swscanf_s( const wchar_t *buffer, const wchar_t *format [, argument ] ...); // <stdio.h> or <wchar.h> int fprintf_s( FILE *stream, const char *format [, argument ]...); // <stdio.h> int fwscanf_s( FILE *stream, const wchar_t *format [, argument ]... ); // <stdio.h> or <wchar.h> int fscanf_s( FILE *stream, const char *format [, argument ]... ); // <stdio.h> int fwscanf_s( FILE *stream, const wchar_t *format [, argument ]... ); // <stdio.h> or <wchar.h> errno_t strcpy_s( char *strDestination, size_t sizeInBytes, const char *strSource ); // <string.h> errno_t wcscpy_s( wchar_t *strDestination, size_t sizeInWords, const wchar_t *strSource ); // <string.h> or <wchar.h> errno_t fopen_s( FILE** pFile, const char *filename, const char *mode ); // <stdio.h> errno_t _wfopen_s( FILE** pFile, const wchar_t *filename, const wchar_t *mode ); // <stdio.h> or <wchar.h> errno_t rand_s( unsigned int* randomValue); // <stdlib.h>

下面是若干安全函数原型用到的数据类型的定义:

#include <crtdefs.h> typedef int errno_t; typedef unsigned short wchar_t; #ifdef _WIN64 typedef unsigned __int64 size_t; #else typedef _W64 unsigned int size_t; #endif

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值