_mbsnbcpy_s_mbsnbcpy_s_l

将字符串的 n 个字节复制到目标字符串。 这些版本的 _mbsnbcpy_mbsnbcpy_l 具有安全增强功能,如 CRT 中的安全功能中所述。

重要

此 API 不能用于在 Windows 运行时中执行的应用程序。 有关详细信息,请参阅通用 Windows 平台应用中不支持的 CRT 函数

语法

errno_t _mbsnbcpy_s(
   unsigned char * strDest,
   size_t sizeInBytes,
   const unsigned char * strSource,
   size_t count
);
errno_t _mbsnbcpy_s_l(
   unsigned char * strDest,
   size_t sizeInBytes,
   const unsigned char * strSource,
   size_t count,
   _locale_t locale
);
template <size_t size>
errno_t _mbsnbcpy_s(
   unsigned char (&strDest)[size],
   const unsigned char * strSource,
   size_t count
); // C++ only
template <size_t size>
errno_t _mbsnbcpy_s_l(
   unsigned char (&strDest)[size],
   const unsigned char * strSource,
   size_t count,
   _locale_t locale
); // C++ only

参数

strDest
要复制的字符串的目标。

sizeInBytes
目标缓冲区大小。

strSource
要复制的字符串。

count
要复制的字节数。

locale
要使用的区域设置。

返回值

如果成功则为零;如果传入的参数不正确则为 EINVAL

注解

_mbsnbcpy_s 函数将 count 个字节从 strSource 复制到 strDest。 如果 count 超出 strDest 的大小,输入字符串中的任意一个为 null 指针,或者 sizeInBytescount 为 0,则此函数将调用无效参数处理程序,如参数验证中所述。 如果允许执行继续,则该函数将返回 EINVAL。 如果源和目标字符串重叠,则 _mbsnbcpy_s 的行为是未定义的。

输出值受区域设置的 LC_CTYPE 类别设置的影响。 有关详细信息,请参阅 setlocale。 这些不带 _l 后缀的函数的版本使用为该区域设置相关的行为的当前区域设置;带有 _l 后缀的版本相同,只不过它们使用传递的区域设置参数。 有关详细信息,请参阅 Locale

注意

与此函数的不安全版本不同,_mbsnbcpy_s 不执行任何 Null 填充并始终以 Null 作为字符串结尾。

在 C++ 中,使用这些函数由模板重载简化;重载可以自动推导出缓冲区长度 (不再需要指定大小自变量),并且它们可以自动用以更新、更安全的对应物替换旧的、不安全的函数。 有关详细信息,请参阅安全模板重载

这些函数的调试库版本首先用 0xFE 填充缓冲区。 若要禁用此行为,请使用 _CrtSetDebugFillThreshold

默认情况下,此函数的全局状态范围限定为应用程序。 若要更改此行为,请参阅 CRT 中的全局状态

一般文本例程映射

Tchar.h 例程 _UNICODE_MBCS 未定义 _MBCS 已定义 _UNICODE 已定义
_tcsncpy_s _strncpy_s _mbsnbcpy_s _wcsncpy_s
_tcsncpy_s_l _strncpy_s_l _mbsnbcpy_s_l _wcsncpy_s_l

要求

例程 必需的标头
_mbsnbcpy_s <mbstring.h>
_mbsnbcpy_s_l <mbstring.h>

有关兼容性的详细信息,请参阅 兼容性

另请参阅

字符串操作
_mbsnbcat_mbsnbcat_l
_mbsnbcmp_mbsnbcmp_l
_strncnt_wcsncnt_mbsnbcnt_mbsnbcnt_l_mbsnccnt_mbsnccnt_l
_mbsnbicmp_mbsnbicmp_l
_mbsnbset_mbsnbset_l
strncpy_strncpy_lwcsncpy_wcsncpy_l_mbsncpy_mbsncpy_l