命名空间
变体
操作

std::messages<CharT>::get, std::messages<CharT>::do_get

来自 cppreference.cn
< cpp‎ | locale‎ | messages
 
 
 
 
 
定义于头文件 <locale>
public:
string_type get( catalog cat, int set, int msgid, const string_type& dfault ) const;
(1)
protected:
virtual string_type do_get( catalog cat, int set, int msgid, const string_type& dfault ) const;
(2)
1) 公有成员函数,调用最派生类的受保护虚成员函数 do_get
2) 以实现定义的方式,使用值 catsetmsgiddfault 从打开的消息目录 cat 中获取消息。如果目录中找不到预期的消息,则返回 dfault 的副本。

目录

[edit] 参数

cat - open() 获取且尚未传递给 close() 的消息目录标识符
set - 实现定义的参数,POSIX 中的消息集
msgid - 实现定义的参数,POSIX 中的消息 ID
dfault - 要在目录中查找的字符串(如果目录使用字符串查找),以及在失败时返回的字符串

[edit] 返回值

来自目录的消息,如果未找到,则为 dfault 的副本。

[edit] 注释

在 POSIX 系统上,此函数调用通常转换为对 catgets() 的调用,参数 setmsgiddfault 按原样传递给 catgets()。在 GNU libstdc++ 中,此函数忽略 setmsgid,并在所需的区域设置中简单地调用 GNU gettext(dfault)

[edit] 示例

以下示例演示了消息的检索:在典型的 GNU/Linux 系统上,它从 /usr/share/locale/de/LC_MESSAGES/sed.mo 读取。

#include <iostream>
#include <locale>
 
int main()
{
    std::locale loc("de_DE.utf8");
    std::cout.imbue(loc);
    auto& facet = std::use_facet<std::messages<char>>(loc);
    auto cat = facet.open("sed", loc);
    if (cat < 0)
        std::cout << "Could not open german \"sed\" message catalog\n";
    else
        std::cout << "\"No match\" in German: "
                  << facet.get(cat, 0, 0, "No match") << '\n'
                  << "\"Memory exhausted\" in German: "
                  << facet.get(cat, 0, 0, "Memory exhausted") << '\n';
    facet.close(cat);
}

可能的输出

"No match" in German: Keine Übereinstimmung
"Memory exhausted" in German: Speicher erschöpft

[edit] 参见