std::tolower
提供: cppreference.com
ヘッダ <cctype> で定義 | ||
int tolower(int ch ); | ||
現在設定されている C のロケールによって定義されている文字変換ルールに従って、指定された文字を小文字に変換します。
デフォルトの "C" ロケールでは、大文字 ABCDEFGHIJKLMNOPQRSTUVWXYZ
が対応する小文字 abcdefghijklmnopqrstuvwxyz
に置き換えられます。
目次 |
[編集]引数
ch | - | 変換する文字。 ch の値が unsignedchar で表現できず、 EOF とも等しくない場合、動作は未定義です |
[編集]戻り値
ch
の小文字バージョン、または現在の C のロケールに小文字のバージョンがない場合は無変更の ch
。
[編集]ノート
<cctype> の他のすべての関数と同様に、引数の値が unsignedchar で表現できず、 EOF
とも等しくない場合、 std::tolower
の動作は未定義です。 プレーンな char (または signedchar) でこれらの関数を安全に使用するためには、まず引数を unsignedchar に変換するべきです。
char my_tolower(char ch){returnstatic_cast<char>(std::tolower(static_cast<unsignedchar>(ch)));}
同様に、イテレータの値型が char または signedchar のとき、標準のアルゴリズムで直接これらを使用するべきではありません。 代わりに、まず値を unsignedchar に変換してください。
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[](unsignedchar c){return std::tolower(c);}// correct);return s;}
[編集]例
Run this code
#include <iostream>#include <cctype>#include <clocale> int main(){unsignedchar 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 ファセットを使用して文字を小文字に変換します (関数テンプレート) | |
ワイド文字を小文字に変換します (関数) | |
tolower の C言語リファレンス |