命名空间
变体
操作

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

来自 cppreference.com
< 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) 使用以实现定义的方式在打开的消息目录 cat 中使用值 setmsgiddfault 获取消息。 如果在目录中找不到预期的消息,则返回 dfault 的副本。

内容

[编辑] 参数

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

[编辑] 返回值

目录中的消息或 dfault 的副本,如果未找到任何消息。

[编辑] 注释

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

[编辑] 示例

以下示例演示了消息检索:在典型的 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

[编辑] 另请参阅