std::messages<CharT>::close, std::messages<CharT>::do_close
来自cppreference.com
本地化库
本地环境与平面 | |||||||||||||||||||||
本地环境 | |||||||||||||||||||||
平面类别基类 | |||||||||||||||||||||
ctype(字符类别)平面 | |||||||||||||||||||||
numeric(数值)平面 | |||||||||||||||||||||
collate(对照比较)平面 | |||||||||||||||||||||
time(时间)平面 | |||||||||||||||||||||
monetary(货币)平面 | |||||||||||||||||||||
messages(消息)平面 | |||||||||||||||||||||
字符分类与转换 | |||||||||||||||||||||
字符分类 | |||||||||||||||||||||
转换 | |||||||||||||||||||||
|
|||||||||||||||||||||
编码转换平面 | |||||||||||||||||||||
|
|
||||||||||||||||||||
C 本地环境 | |||||||||||||||||||||
std::messages
成员函数 | ||||
messages::closemessages::do_close
|
在标头
<locale>
定义
|
||
public:
void close( catalog c ) const; |
(1) | |
protected:
virtual void do_close( catalog c ) const; |
(2) | |
1) 公开成员函数,调用最终导出类的受保护虚成员函数 do_close
。
2) 释放与从 open()
获得的 catalog
类型(继承自 std::messages_base )值 c
所指代的打开目录关联的实现定义资源。
参数
c | - | 合法的打开的目录标识符,仍未在其上调用 close()
|
返回值
(无)
注意
POSIX 系统上,此函数调用通常翻译为调用
catclose()
。 GNU libstdc++ 中,它以 GNU gettext()
实现,并不做任何事。
示例
下列代码演示消息取得:典型的 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