在常规的编程任务中使用新的 <tuple> 库
2007-03-15 21:55:17 来源:WEB开发网typedef tuple<int, FILE *> file_t;
file_t convert_filename(const char* path);
在面向对象环境中,你也可以扩展 file_t 为一个适合的 fstream 对象。
tuple 提供了一个优雅的解决方案来解决另外一个问题,就是用整型来仿真浮点值。现在你可以借助 tuple 用两个纯粹的整型替代:
typedef tuple<__int64, int> Currency;
例如,有一个 USD 类:
class USD
{
private:
Currency curr;
public:
explicit USD(__int64 d=0, int c=0): curr(d,c) {}
//..
};
注意有一个非常重要的地方是数据成员声明为私有。该类的使用者将不会注意其实现已经改变,因为接口完好无损。
这样做非常好,你可能会问:“难道不能把两个整型打包在一个定义良好的结构里来实现吗?”当然可以,但是,tuple 有一个结构所没有的优势:那就是它已经重载了关系操作符 <、>、== 等。因此,你可以象下面这样轻松地比较两个货币的值:
bool operator==(const USD& u1, const USD& u2)
{
return u1.curr==u2.curr;
}
这里,当且仅当 u1 中的每一个元素与 u2 中对应的元素相等时,tuple 重载的 == 才返回true,例如:
Currency curr1(100,99);
Currency curr2(100,98);
Currency curr3(100,98);
bool res=curr1==curr2; //false
res=curr2==curr3; //true
4、tuple 使用之最
Tuple 有许多其它用途。例如,你可以象下面这样创建一个 tuple 引用和 cv 限定类型:
int i; char c;
make_tuple(ref(i),ref(c)); // tuple <int &, char&>
make_tuple(cref(i), c); // tuple <const int &, char>
ref 类模板充当引用包装器。同样,cref 将引用包装成常量(const)对象。为了简化引用元素的 tuple 的创建过程,可以用 tie()函数:
tie(i, c); //等同于:make_tuple(ref(i), ref(c));
包含非常量引用元素的 tuple 可被用于将另外的 tuple “解包(unpack)”成实际的对象。
tie(i, c)=make_tuple(1, ''a'');
经过这样的赋值,i=1,c=''a''。这个技术在解包返回 tuple 的函数时很有用。
作者简介
Danny Kalev 是一名通过认证的系统分析师,专攻 C++ 和形式语言理论的软件工程师。1997 年到 2000 年期间,他是 C++ 标准委员会成员。最近他以优异成绩完成了他在普通语言学研究方面的硕士论文。 业余时间他喜欢听古典音乐,阅读维多利亚时期的文学作品,研究 Hittite、Basque 和 Irish Gaelic 这样的自然语言。其它兴趣包括考古和地理。Danny 时常到一些 C++ 论坛并定期为不同的 C++ 网站和杂志撰写文章。他还在教育机构讲授程序设计语言和应用语言课程。
更多精彩
赞助商链接