std::tolower
From cppreference.com
| ヘッダー <cctype> で定義 |
||
| int tolower( int ch ); |
||
現在インストールされているCロケールによって定義された文字変換規則に従って、指定された文字を小文字に変換します。
デフォルトの"C"ロケールでは、大文字の ABCDEFGHIJKLMNOPQRSTUVWXYZ は、それぞれの小文字 abcdefghijklmnopqrstuvwxyz に置き換えられます。
目次 |
[編集] パラメーター
| 文字 | - | 変換される文字。 ch の値が unsigned char として表現できず、 EOF に等しくない場合、動作は未定義です。 |
[編集] 戻り値
ch の小文字バージョン。または、現在のCロケールで小文字バージョンがリストされていない場合は、変更されない ch。
[編集] 注記
<cctype> の他のすべての関数と同様に、引数の値が unsigned char として表現できず、 EOF と等しくない場合、 std::tolower の動作は未定義です。これらの関数を通常の char(または signed char)で安全に使用するには、引数をまず unsigned char に変換する必要があります。
char my_tolower(char ch) { return static_cast<char>(std::tolower(static_cast<unsigned char>(ch))); }
同様に、イテレータの値型がcharまたはsigned charである場合、標準アルゴリズムで直接使用しないでください。代わりに、まず値をunsigned charに変換してください。
std::string str_tolower(std::string s) { std::transform(s.begin(), s.end(), s.begin(), // static_cast<int(*)(int)>(std::tolower) // wrong // [](int c){ return std::tolower(c); } // wrong // [](char c){ return std::tolower(c); } // wrong [](unsigned char c){ return std::tolower(c); } // correct ); return s; }
[編集] 例
このコードを実行
#include <cctype> #include <clocale> #include <iostream> int main() { unsigned char c = '\xb4'; // the character Ž in ISO-8859-15 // but ´ (acute accent) in ISO-8859-1 std::setlocale(LC_ALL, "en_US.iso88591"); std::cout << std::hex << std::showbase; std::cout << "in iso8859-1, tolower('0xb4') gives " << std::tolower(c) << '\n'; std::setlocale(LC_ALL, "en_US.iso885915"); std::cout << "in iso8859-15, tolower('0xb4') gives " << std::tolower(c) << '\n'; }
実行結果の例
in iso8859-1, tolower('0xb4') gives 0xb4
in iso8859-15, tolower('0xb4') gives 0xb8[編集] 関連項目
| 文字を大文字に変換する (関数) | |
ロケールの ctype ファセットを使用して文字を小文字に変換する(関数テンプレート) | |
| ワイド文字を小文字に変換する (関数) | |
| Cドキュメント ( tolower について)
| |
[編集] 外部リンク
| 1. | ISO/IEC 8859-1。Wikipediaより。 |
| 2. | ISO/IEC 8859-15。Wikipediaより。 |