次の方法で共有


_strncnt、_wcsncnt、_mbsnbcnt、_mbsnbcnt_l、_mbsnccnt、_mbsnccnt_l

指定されたカウント内で文字数またはバイト数を返します。

重要

_mbsnbcnt、_mbsnbcnt_l、_mbsnccnt、および _mbsnccnt_l は、Windows ランタイムで実行するアプリケーションでは使用できません。詳細については、「/ZW でサポートされない CRT 関数」を参照してください。

size_t _strncnt(
   const char *str,
   size_t count
);
size_t _wcsncnt(
   const wchar_t *str,
   size_t count
);
size_t _mbsnbcnt(
   const unsigned char *str,
   size_t count 
);
size_t _mbsnbcnt_l(
   const unsigned char *str,
   size_t count,
   _locale_t locale
);
size_t _mbsnccnt(
   const unsigned char *str,
   size_t count
);
size_t _mbsnccnt_l(
   const unsigned char *str,
   size_t count,
   _locale_t locale
);

パラメーター

  • str
    調査する文字列。

  • count
    str で調査する文字数またはバイト数。

  • locale
    使用するロケール。

戻り値

_mbsnbcnt と _mbsnbcnt_l は、str の最初の count マルチバイト文字で見つかったバイト数を返します。 _mbsnccnt と _mbsnccnt_l は、str の最初の count バイトで見つかった文字数を返します。 str の調査が完了する前に NULL 文字が検出された場合、NULL 文字よりも前に見つかったバイト数または文字数を返します。 str が count の文字数またはバイト数よりも少ない数で構成されている場合は、文字列の文字数またはバイト数を返します。 count が 0 より小さい場合は、0 を返します。 以前のバージョンでは、これらの関数は、size_t 型ではなく int 型の戻り値を使用していました。

_strncnt は、1 バイト文字列 str の最初の count バイトにある文字数を返します。 _wcsncnt は、ワイド文字列 str の最初の count ワイド文字にある文字数を返します。

解説

_mbsnbcnt と _mbsnbcnt_l は、str の最初の count マルチバイト文字で見つかったバイト数をカウントします。 _mbsnbcnt と _mbsnbcnt_l は mtob の代わりとなる関数です。この 2 つの関数は mtob の代わりに使用する必要があります。

_mbsnccnt と _mbsnccnt_l は、str の最初の count バイトで見つかった文字数をカウントします。 _mbsnccnt と _mbsnccnt_l が 2 バイト文字の 2 番目のバイトで NULL を検出すると、最初のバイトも NULL と見なされ、戻されるカウント値に含まれません。 _mbsnccnt と _mbsnccnt_l は btom の代わりとなる関数です。この 2 つの関数は btom の代わりに使用する必要があります。

str が null ポインターであるか、count が 0 の場合、「パラメーターの検証」で説明されているように、これらの関数は無効なパラメーター ハンドラーを呼び出します。また、errno を EINVAL に設定し、0 を返します。

出力値は、ロケールの LC_CTYPE カテゴリの設定で決まります。詳細については、「setlocale」を参照してください。 _l サフィックスが付いていないこの関数のバージョンでは、このロケールに依存する動作に現在のロケールを使用します。_l サフィックスが付いているバージョンは、渡されたロケール パラメーターを代わりに使用する点を除いて同じです。 詳細については、「ロケール」を参照してください。

汎用テキスト ルーチンのマップ

ルーチン

_UNICODE および _MBCS が未定義の場合

_MBCS が定義されている場合

_UNICODE が定義されている場合

_tcsnbcnt

_strncnt

_mbsnbcnt

_wcsncnt

_tcsnccnt

_strncnt

_mbsnbcnt

 n/a

_wcsncnt

 n/a

 n/a

_mbsnbcnt

_wcsncnt

 n/a

 n/a

_mbsnccnt

n/a

n/a

_mbsnbcnt_l

_mbsnccnt_l

必要条件

ルーチン

必須ヘッダー

_mbsnbcnt

<mbstring.h>

_mbsnbcnt_l

<mbstring.h>

_mbsnccnt

<mbstring.h>

_mbsnccnt_l

<mbstring.h>

_strncnt

<tchar.h>

_wcsncnt

<tchar.h>

互換性の詳細については、「互換性」を参照してください。

使用例

// crt_mbsnbcnt.c

#include  <mbstring.h>
#include  <stdio.h>

int main( void )
{
   unsigned char str[] = "This is a multibyte-character string.";
   unsigned int char_count, byte_count;
   char_count = _mbsnccnt( str, 10 );
   byte_count = _mbsnbcnt( str, 10 );
   if ( byte_count - char_count )
      printf( "The first 10 characters contain %d multibyte characters\n", char_count );
   else
      printf( "The first 10 characters are single-byte.\n");
}

出力

The first 10 characters are single-byte.

同等の .NET Framework 関数

使用できません。標準 C 関数を呼び出すには、PInvoke を使用します。詳細については、「プラットフォーム呼び出しの例」を参照してください。

参照

関連項目

文字列操作 (CRT)

ロケール

マルチバイト文字のシーケンスの解釈

_mbsnbcat、_mbsnbcat_l