我正在开发一个项目,需要一个通用的C++封装器来处理大数库。如果该库提供了类似以下的C风格函数:
//assignment
lib_set(lib_type data, lib_type input);
lib_set_si(lib_type data, long input);
lib_set_ui(lib_type data, unsigned long input);
//addition
lib_add(lib_type data, lib_type input);
lib_add_ui(lib_type data, unsigned long input);
为了避免在不必要的情况下创建临时对象,我最终得到了像这样的代码:
class wrapper
{
private:
lib_type data;
public:
wrapper()
{
lib_set_ui(this->data, 0UL);
}
wrapper (const wrapper &input)
{
lib_set(this->data, input.data);
}
wrapper (const long input)
{
lib_set_si(this->data, input);
}
wrapper (const unsigned long input)
{
lib_set_ui(this->data, input);
}
wrapper &operator+= (const wrapper &input)
{
lib_add(this->data, input.data);
return *this;
}
wrapper &operator+= (const unsigned long input)
{
lib_add_ui(this->data, input);
return *this;
}
};
不幸的是,如果我这样做:
wrapper x(2);
x += -2;
编译器(GCC / VS2010)甚至不会发出警告,提示我正在尝试将 int 显式转换为 unsigned long,这绝对不是我想要的结果...
所以,在这种情况下,如何为包装器类(wrapper class)重载运算符,使得在不需要创建临时 wrapper 对象时也能正常工作?如果我删除 wrapper &operator+= (const unsigned long input) 重载,则必须使用以下内容:
wrapper x(2);
x += wrapper(-2);
x += -2;//implicitly casts -2 to wrapper
但我认为我不能依赖于编译器可能能够优化掉额外的对象这一事实...
const long
参数版本的这两个参数进行调用。可能甚至没有进行任何转换。 - user308323int64_t
/uint64_t
)或你的数据所需的最大类型即可。 - Andrei Tita