名前空間
変種
操作

std::ctype<CharT>::tolower, std::ctype<CharT>::do_tolower

提供: cppreference.com
< cpp‎ | locale‎ | ctype
 
 
 
 
ヘッダ <locale> で定義
public:
CharT tolower( CharT c ) const;
(1)
public:
const CharT* tolower( CharT* beg, const CharT* end ) const;
(2)
protected:
virtual CharT do_tolower( CharT c ) const;
(3)
protected:
virtual const CharT* do_tolower( CharT* beg, const CharT* end ) const;
(4)
1,2) public メンバ関数。 最も派生したクラスの protected virtual メンバ関数 do_tolower を呼びます。
3) このロケールによって小文字形が定義されていれば、文字 c を小文字に変換します。
4) 文字配列 [beg, end) 内のすべての文字について、小文字形が存在すれば、その文字をその小文字形に変換します。

目次

[編集] 引数

c - 変換する文字
beg - 変換する文字の配列の最初の文字へのポインタ
end - 変換する文字の配列の最後の次へのポインタ

[編集] 戻り値

1,3) 小文字、またはこのロケールに小文字がリストされていなければ c
2,4) end

[編集] ノート

1:1 の文字マッピングのみがこの関数によって行うことができます。 例えばギリシア語の大文字 'Σ' には単語内の位置に依存する2つの小文字形 'σ' および 'ς' があります。 この場合、正しい小文字形を取得するために do_tolower を使用することはできません。

[編集]

#include <locale>
#include <iostream>
 
void try_lower(const std::ctype<wchar_t>& f, wchar_t c)
{
    wchar_t up = f.tolower(c);
    if (up != c) {
        std::wcout << "Lower case form of \'" << c << "' is " << up << '\n';
    } else {
        std::wcout << '\'' << c << "' has no lower case form\n";
    }
}
 
int main()
{
    std::locale::global(std::locale("en_US.utf8"));
    std::wcout.imbue(std::locale());
    std::wcout << "In US English UTF-8 locale:\n";
    auto& f = std::use_facet<std::ctype<wchar_t>>(std::locale());
    try_lower(f, L'Σ');
    try_lower(f, L'Ɛ');
    try_lower(f, L'A');
 
    std::wstring str = L"HELLo, wORLD!";
    std::wcout << "Lowercase form of the string '" << str << "' is ";
    f.tolower(&str[0], &str[0] + str.size());
    std::wcout << "'" << str << "'\n";
}

出力:

In US English UTF-8 locale:
Lower case form of 'Σ' is σ
Lower case form of 'Ɛ' is ɛ
Lower case form of 'A' is a
Lowercase form of the string 'HELLo, wORLD!' is 'hello, world!'

[編集] 関連項目

do_toupper を呼びます
(パブリックメンバ関数) [edit]
文字を小文字に変換します
(関数) [edit]
ワイド文字を小文字に変換します
(関数) [edit]