命名空间
变体
操作

operator<<,>>(std::linear_congruential_engine)

来自 cppreference.cn
 
 
 
 
 
template< class CharT, class Traits >

friend std::basic_ostream<CharT, Traits>&
    operator<<( std::basic_ostream<CharT, Traits>& os,

                const linear_congruential_engine& e );
(1) (C++11 起)
template< class CharT, class Traits >

friend std::basic_istream<CharT, Traits>&
    operator>>( std::basic_istream<CharT, Traits>& is,

                linear_congruential_engine& e );
(2) (C++11 起)
1)e 的当前状态的文本表示写入 os,其格式标志设置为 std::ios_base::dec | std::ios_base::left,填充字符设置为 空格。
写入后,os 的原始 fmtflags 和填充字符将被恢复。
2)is 读取引擎状态的文本表示(记作 text),其格式标志设置为 std::ios_base::dec,并将 e 的状态设置为该状态。
读取后,is 的原始 fmtflags 将被恢复。
  • 如果 text 之前未使用输出流 pr 写入,则行为未定义。
  • 否则,如果以下任何一个值为 false,则行为未定义:
  • is.getloc() == pr.getloc()
  • std::is_same<decltype(is)::char_type,
                 decltype(pr)::char_type>::value
  • std::is_same<decltype(is)::traits_type,
                 decltype(pr)::traits_type>::value
  • 否则,如果 text 不是 decltype(e) 任何状态的有效文本表示,则 e 的状态保持不变,并调用 is.setstate(std::ios_base::failbit)
  • 否则,给定一个与 e 类型相同的另一个引擎 eng。如果 text 之前是由 pr << eng 写入的,并且在 pr << engis >> e 之间没有对 eeng 的任何调用,则 e == engtrue

这些函数模板对普通的非限定限定查找不可见,只能通过实参依赖查找找到,当 decltype(e) 是参数的关联类时。

目录

[编辑] 参数

os - 要插入数据的输出流
is - 用于提取数据的输入流
e - 伪随机数引擎

[编辑] 返回值

1) os
2) is

[编辑] 复杂度

1,2) 常数时间。

[编辑] 异常

2) 当设置 std::ios_base::failbit 时,可能抛出 std::ios_base::failure

缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

缺陷报告 应用于 发布时的行为 正确的行为
LWG 3519 C++11 插入和提取运算符的形式未指定 指定为隐藏友元