sprintf_s was not declared in this scope

前端 未结 6 1197
悲&欢浪女
悲&欢浪女 2021-01-01 10:28

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 dec         


        
相关标签:
6条回答
  • 2021-01-01 10:57

    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;
    }
    
    0 讨论(0)
  • 2021-01-01 11:00

    It's not standard, you won't find such function on Linux.

    Standard function snprintf should have a similar semantics.

    0 讨论(0)
  • 2021-01-01 11:09

    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.

    0 讨论(0)
  • 2021-01-01 11:12

    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.

    0 讨论(0)
  • 2021-01-01 11:16

    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.

    0 讨论(0)
  • 2021-01-01 11:19

    sprintf_s is only part of Annex K, an optional Annex to the C11 standard:

    Annex K

    ...

    K.2 Scope

    1. 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.

    0 讨论(0)
提交回复
热议问题