c++ - C++ 接受错误的返回类型
问题描述
我有以下代码,在我看来,不应该编译:(在class Vector
(不是我定义的std::vector
,而是Vector
我自己定义的)):
Vector operator*(double factor)
{
// some element-wise multiplication here
return factor;
}
我将这个运算符定义为返回 a Vector
,但在方法内部我返回 a double
。
我也没有在类中定义任何隐式转换运算符。
我认为这显然是无效的,但 gcc 很高兴地编译了它,完全没有任何抱怨。
我的第一个反应是向 gcc 提交缺陷报告,但我想我会在此之前问...
我是否在这里遗漏了一些可以解释为什么编译器认为此代码有效的内容?
(如果相关,c++-standard 设置为 c++17)
关于该类的更多信息Vector
:(即,我包括所有声明的构造函数和运算符,因为其他命名函数不应导致此问题):
class Vector {
public:
Vector(std::vector<double> values);
Vector(size_t dimension, double value);
Vector(size_t dimension);
void operator*=(double factor);
void operator*=(Vector const& factor);
friend Vector operator-(Vector const& a, Vector const& b);
friend Vector operator+(Vector const& a, Vector const& b);
friend Vector operator*(Vector const& a, Vector const& b);
Vector operator*(double factor);
double& operator[](size_t i);
friend std::ostream& operator<<(std::ostream& stream, Vector const& v);
}
解决方案
根据收到的评论给出这个答案:
非显式转换运算符不是最初具有错误类型的返回值可能“成为”函数签名所需类型的唯一方式。构造函数
Vector(size_t dimension);
取一个数值作为参数,它本身不是 a double
,而是 a long unsigned int
,但是 adouble
可以转换成那个。
所以发生的事情double factor
是首先转换为 along unsigned int
然后隐式构造Vector
,使用构造函数Vector(size_t dimension);
发生。然后返回作为此构造结果的对象。
因此,在不违反语言规则的意义上,这是有效的代码,编译器在这里绝对没有做错任何事情。
如果不需要此行为,则应将相关构造函数标记为explicit
:
explicit Vector(size_t dimension);
如果有多个构造函数采用一个double
可以转换为 a 类型的参数,或者其第一个参数满足该要求,而所有其他参数都是可选的,例如:
Vector(int a, char b = 'c');
它们也必须被标记explicit
,但在这种情况下,编译器很可能会抱怨,因为它无法推断出要调用哪个构造函数。
推荐阅读
- php - jquery刷新div内容(php函数不是文件)
- html - 链接区域大于图片
- c++ - C++刷新问题:为什么使用setvbuf后缓冲区之前的一些文本输出已满
- python - Python 中的 Apache Beam SQL 错误 - ValueError:不支持的类型:任何
- r - 在 dplyr 中重新编码以更改导致错误的标签:参数 2 必须命名,而不是未命名
- rabbitmq - 使用 spring-rabbit 从多个 rabbit 队列分片中消费
- python - Sharepoint API Python Office365的身份验证错误-KeyError:'FedAuth'
- python - 从多个 tiff 格式图像中提取帧
- swift - NSImage:直接设置像素的颜色
- node.js - 发出 HTTP 请求以等待特定属性的响应