I have a C program that uses sprintf_s
. It works fine in Windows, but when I compile my code in Linux it gives this error:
sprintf_s was not declared in开发者_如何学C this scope.
Why does this happen and how can I fix it?
It's not standard, you won't find such function on Linux.
Standard function snprintf
should have a similar semantics.
sprintf_s is not part of the standard C library, so it is not portable, thus you are not able to use it in Linux. BUT you have snprintf, which is very similar and it should help you to accomplish what you want.
sprintf_s
is only part of Annex K, an optional Annex to the C11 standard:
Annex K
...
K.2 Scope
- This annex specifies a series of optional extensions that can be useful in the mitigation of security vulnerabilities in programs, and comprise new functions, macros, and types declared or defined in existing standard headers.
...
K.3.5.3.6 The sprintf_s function
Synopsis
#define __STDC_WANT_LIB_EXT1__1 #include <stdio.h> int sprintf_s(char * restrict s, rsize_t n, const char * restrict format, ...);
(emphasis added)
It never made it into POSIX (or Linux) (and is not missed at all, there are even arguments about its usefulness in the committee).
For better portability, use snprintf
which is part of the core standard and provides all the functionality you'll need.
sprintf_s
is not part of the standard C library, and you won't be able to use it in Linux.
However, snprintf
is standard and should do the same task.
During a porting of my program from Windows to Linux, I wrote following implementation in my own windows.h:
inline int sprintf_s(char* buffer, size_t sizeOfBuffer, const char* format, ...)
{
va_list ap;
va_start(ap, format);
int result = vsnprintf(buffer, sizeOfBuffer, format, ap);
va_end(ap);
return result;
}
template<size_t sizeOfBuffer>
inline int sprintf_s(char (&buffer)[sizeOfBuffer], const char* format, ...)
{
va_list ap;
va_start(ap, format);
int result = vsnprintf(buffer, sizeOfBuffer, format, ap);
va_end(ap);
return result;
}
snprintf is insecure, only sprintf_s is secure. snprintf does not guarantee to add a final \0, leading to possible subsequent overflows. look at https://github.com/rurban/safeclib for a proper implementation.
精彩评论