次の方法で共有


_strlwr、_wcslwr、_mbslwr、_strlwr_l、_wcslwr_l、_mbslwr_l

更新 : 2007 年 11 月

文字列を小文字に変換します。これらの関数のセキュリティを強化したバージョンについては、「_strlwr_s、_strlwr_s_l、_mbslwr_s、_mbslwr_s_l、_wcslwr_s、_wcslwr_s_l」を参照してください。

char *_strlwr(
   char * str
);
wchar_t *_wcslwr(
   wchar_t * str
);
unsigned char *_mbslwr(
   unsigned char * str
);
char *_strlwr_l(
   char * str,
   _locale_t locale
);
wchar_t *_wcslwr_l(
   wchar_t * str,
   _locale_t locale
);
unsigned char *_mbslwr_l(
   unsigned char * str,
   _locale_t locale 
);
template <size_t size>
char *_strlwr(
   char (&str)[size]
); // C++ only
template <size_t size>
wchar_t *_wcslwr(
   wchar_t (&str)[size]
); // C++ only
template <size_t size>
unsigned char *_mbslwr(
   unsigned char (&str)[size]
); // C++ only
template <size_t size>
char *_strlwr_l(
   char (&str)[size],
   _locale_t locale
); // C++ only
template <size_t size>
wchar_t *_wcslwr_l(
   wchar_t (&str)[size],
   _locale_t locale
); // C++ only
template <size_t size>
unsigned char *_mbslwr_l(
   unsigned char (&str)[size],
   _locale_t locale 
); // C++ only

パラメータ

  • str
    小文字に変換する、NULL で終わる文字列。

  • locale
    使用するロケール。

戻り値

これらの関数は、変換後の文字列へのポインタを返します。変更は同じ位置で行われるため、入力引数として渡したポインタがそのまま返されます。エラーを示す戻り値は予約されていません。

解説

_strlwr 関数は、str 内のすべての大文字を小文字に、ロケールの LC_CTYPE カテゴリ設定に基づいて変換します。ほかの文字には影響しません。LC_CTYPE の詳細については、「setlocale、_wsetlocale」を参照してください。 _l サフィックスが付いていないこの関数のバージョンでは、現在のロケールを使用してロケールに依存する動作を行います。_l サフィックスが付いているバージョンは、渡されたロケールを代わりに使用する点を除いて同じです。詳細については、「ロケール」を参照してください。

_wcslwr 関数と _mbslwr 関数は、_strlwr 関数のワイド文字バージョンとマルチバイト文字バージョンです。_wcslwr 関数の引数と戻り値はワイド文字列で、_mbslwr 関数の引数と戻り値はマルチバイト文字列です。それ以外では、これらの関数の動作は同じです。

str が NULL ポインタの場合は、「パラメータの検証」に説明されているように、無効なパラメータ ハンドラが呼び出されます。実行の継続が許可された場合、これらの関数は元の文字列を返し、errno を EINVAL に設定します。

C++ では、これらの関数にテンプレートのオーバーロードがあります。このオーバーロードは、これらの関数に対応するセキュリティで保護された新しい関数を呼び出します。詳細については、「セキュリティ保護されたテンプレート オーバーロード」を参照してください。

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

TCHAR.H のルーチン

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

_MBCS が定義されている場合

_UNICODE が定義されている場合

_tcslwr

_strlwr

_mbslwr

_wcslwr

_tcslwr_l

_strlwr_l

_mbslwr_l

_wcslwr_l

必要条件

ルーチン

必須ヘッダー

_strlwr, _strlwr_l

<string.h>

_wcslwr, _wcslwr_l

<string.h> または <wchar.h>

_mbslwr, _mbslwr_l

<mbstring.h>

互換性の詳細については、「C ランタイム ライブラリ」の「互換性」を参照してください。

使用例

// crt_strlwr.c
// compile with: /W3
// This program uses _strlwr and _strupr to create
// uppercase and lowercase copies of a mixed-case string.
#include <string.h>
#include <stdio.h>

int main( void )
{
   char string[100] = "The String to End All Strings!";
   char * copy1 = _strdup( string ); // make two copies
   char * copy2 = _strdup( string );

   _strlwr( copy1 ); // C4996
   // Note: _strlwr is deprecated; consider using _strlwr_s instead
   _strupr( copy2 ); // C4996
   // Note: _strupr is deprecated; consider using _strupr_s instead

   printf( "Mixed: %s\n", string );
   printf( "Lower: %s\n", copy1 );
   printf( "Upper: %s\n", copy2 );

   free( copy1 );
   free( copy2 );
}

Mixed: The String to End All Strings!
Lower: the string to end all strings!
Upper: THE STRING TO END ALL STRINGS!

.NET Framework の相当するアイテム

System::String::ToLower

参照

参照

文字列操作 (CRT)

ロケール

_strupr、_strupr_l、_mbsupr、_mbsupr_l、_wcsupr_l、_wcsupr