public member function
<locale>

std::time_get::get_monthname

iter_type get_monthname ( iter_type s, iter_type end, ios_base& str,                          ios_base::iostate& err, tm* t) const;
读取月份名称
解析 send 之间的字符序列,代表月份的名称,并将其值存储到 t 指向的 tm 对象中。

该函数会读取字符,直到读取的字符不再是有效的月份表达式的一部分,或者达到 end。序列中的下一个字符将由函数返回的迭代器指向。

如果成功,该函数将设置 tm 结构体 t 的相关成员。其余成员将保持不变。

在内部,此函数仅调用虚保护成员函数 do_get_monthname,该函数默认使用未指定的格式解析代表月份名称的字符序列(通常与 strftime"%b""%B" 格式化输出相同)。

必要时,该函数会更新 err 以反映操作结果。
- 如果序列格式无效,函数将设置 failbit
- 否则,行为未指定,但某些实现会将 err 设置为 eofbit(如果函数耗尽了字符序列,即到达了 end,无论是成功还是失败),或者设置为 goodbit
必要时,该函数会更新 err 以反映操作结果。
- 如果序列格式无效,函数将设置 failbit
- 如果函数在操作过程中耗尽了字符序列(即到达了 end),它会将 eofbit 设置(单个操作可能设置 failbiteofbit)。
- 否则,行为是未定义的,尽管某些实现会将 err 设置为 goodbit

参数

s, end
指向序列开始和结束字符的迭代器。使用的范围是 [s,end),它包含 send 之间的所有字符,包括 s 指向的字符,但不包括 end 指向的字符。
成员类型 iter_type 是该 facet 的迭代器类型(定义为 time_get 的第二个模板参数 InputIterator 的别名)。默认情况下,它是一个 istreambuf_iterator,允许从 basic_istream 对象进行隐式转换。
str
派生自 ios_base 的类对象(通常是输入流对象)。它仅用于获取格式信息。
err
流错误状态对象,类型为 ios_base::iostate,用于存储错误状态。
t
指向 struct tm (在头文件 <ctime> 中定义)的指针,其成员在成功调用此成员函数后会被设置。

返回值

在操作之后,序列中紧随最后一个被使用字符的下一个字符。
成员类型 iter_type 是此 facet 的迭代器类型(定义为 time_get 的第二个模板参数 InputIterator 的别名)。

示例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
// time_get::get_monthname example
#include <iostream>       // std::cout, std::ios
#include <sstream>        // std::istringstream
#include <ctime>          // std::tm
#include <locale>         // std::locale, std::time_get, std::use_facet

int main ()
{
  std::locale loc;        // classic "C" locale

  // get time_get facet:
  const std::time_get<char>& tmget = std::use_facet <std::time_get<char> > (loc);

  std::ios::iostate state;
  std::istringstream iss ("August");
  std::tm when;

  tmget.get_monthname (iss, std::time_get<char>::iter_type(), iss, state, &when);

  std::cout << "month: " << (when.tm_mon + 1) << '\n';
  return 0;
}

可能的输出

month: 8


数据竞争

访问该对象以及 send 之间的整个范围。
参数 strerrt 可能会被修改。

异常安全

如果抛出异常,则“facet 对象”不会发生更改,尽管某些参数可能已被修改。

另见