我有一个纯虚拟类CF
,表示1D中的任何连续函数,它被定义为头文件
// tools.h
class CF
{
public:
virtual double operator()(double x) const=0 ;
};
我打算做的是使用仿函数包装几个简单的函数,并在tools.h
中定义它们。如果我使用匿名类,例如:
// tools.h
class : public CF{
public:
virtual double operator()(double x) const { return 0.0; }
} zero;
然后我遇到了麻烦,正确地重新定义了类,包括tools.h
。 gcc抱怨道:
// tools.h included in main.cpp, foo.cpp, and bar.cpp
foo.o:(.bss+0x0): multiple definition of `zero'
main.o:(.bss+0x0): first defined here
bar.o:(.bss+0x0): multiple definition of `zero'
main.o:(.bss+0x0): first defined here
我想我可以通过做类似的事情来解决这个问题:
// tools.h
class zero_: public CF{
public:
virtual double operator()(double x) const { return 0.0; }
};
const static zero_ zero;
但我不喜欢它,因为zero_
随处可见,我不需要它!我该如何解决这个问题?
答案 0 :(得分:2)
不做。只是
struct zero : public CF {
double operator()(double x) { return 0.; }
};
并与
一起使用void fun(const CF& cf);
fun(zero());
将函数放在函数上的一个原因是它们能够通过操作来携带和暴露状态,你的方法会抛弃它以简洁地获得2个括号。