Sdílet prostřednictvím


_mbsnbcpy, _mbsnbcpy_l

Kopie n bajtů řetězce pro cílový řetězec.Bezpečnější verze tyto funkce jsou k dispozici, naleznete v _mbsnbcpy_s, _mbsnbcpy_s_l.

Důležitá poznámkaDůležité

Toto rozhraní API nelze použít v aplikacích, které jsou spuštěny v prostředí Windows Runtime.Další informace naleznete v tématu CRT funkce nejsou podporovány s /ZW.

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

Parametry

  • strDest
    Cíl pro řetězec znaků, které mají být zkopírovány.

  • strSource
    Znakový řetězec, který chcete zkopírovat.

  • count
    Počet bajtů, které mají být zkopírovány.

  • locale
    Chcete-li národní prostředí pro použití.

Vrácená hodnota

_mbsnbcpyvrací ukazatel na řetězec znaků cíl.Žádné vrácená hodnota je vyhrazena udávající chybu.

Poznámky

The _mbsnbcpy function copies count bytes from strSource to strDest.Pokud count přesahuje velikost strDest nebo zdrojového a cílového řetězce překrývají, chování _mbsnbcpy není definován.

Pokud strSource nebo strDest ukazatel s hodnotou null, je tato funkce vyvolá obslužnou rutinu neplatný parametr, jak je popsáno v Ověření parametru.Pokud je povoleno zpracování, chcete-li pokračovat, vrátí funkce NULL a errno na EINVAL.

Výstupní hodnota je ovlivněna nastavením LC_CTYPE kategorie nastavení národního prostředí; Viz setlocale, _wsetlocale Další informace.Verze tyto funkce jsou shodné, s výjimkou, že ty, které nemají _l příponu použít aktuální národní prostředí a verze, které mají _l přípony, použijte parametr locale, který je předán v.Další informace naleznete v tématu Národní prostředí.

Poznámka k zabezpečeníPoznámka k zabezpečení

Tyto funkce může být zranitelný vůči hrozbám přetečení vyrovnávací paměti.Přeběhy vyrovnávací paměti lze provést libovolný útočník kód, který může způsobit, že bude vyplacena neoprávněně zvýšení úrovně oprávnění a napadnout počítač se systémem.Další informace naleznete v tématu Zamezení způsobí přetečení vyrovnávací paměti.

V jazyce C++ mají tyto funkce šablony přetížení, které vyvolávají novější, bezpečnější protějšky těchto funkcí.Další informace naleznete v tématu Přetížení zabezpečení šablony.

Mapování rutiny obecného textu

Byla zahájena rutina Tchar.h

_UNICODE a _MBCS není definováno

_MBCS, definice

_UNICODE definována

_tcsncpy

strncpy

_mbsnbcpy

wcsncpy

_tcsncpy_l

_strncpy_l

_mbsnbcp_l

_wcsncpy_l

Požadavky

Byla zahájena rutina

Požadované záhlaví

_mbsnbcpy

<mbstring.h>

_mbsnbcpy_l

<mbstring.h>

Další informace o kompatibilitě v tématu Kompatibilita.

Ekvivalent v rozhraní .NET Framework

Nelze použít Volání funkce standardním C pomocí PInvoke. Další informace naleznete v tématu Příklady vyvolání platformy.

Viz také

Referenční dokumentace

Zacházení s řetězci (CRT)

_mbsnbcat, _mbsnbcat_l

_mbsnbcmp, _mbsnbcmp_l

_strncnt, _wcsncnt, _mbsnbcnt, _mbsnbcnt_l, _mbsnccnt, _mbsnccnt_l

_mbsnbset, _mbsnbset_l

strncpy, _strncpy_l, wcsncpy, _wcsncpy_l, _mbsncpy, _mbsncpy_l