错误:将“const A”作为“void A::hi()”的“this”参数传递会丢弃限定符[-fppermissive]
我不明白为什么会出现这个错误,我没有返回任何东西,只是传递了对象的引用,就是这样。
#include <iostream>
class A
{
public:
void hi()
{
std::cout << "hi." << std::endl;
}
};
class B
{
public:
void receive(const A& a) {
a.hi();
}
};
class C
{
public:
void receive(const A& a) {
B b;
b.receive(a);
}
};
int main(int argc, char ** argv)
{
A a;
C c;
c.receive(a);
return 0;
}
编辑
我用const correction修复了它,但是现在我试图在同一个方法中调用方法,我得到了同样的错误,但奇怪的是我没有传递这个方法的引用。
#include <iostream>
class A
{
public:
void sayhi() const
{
hello();
world();
}
void hello()
{
std::cout << "world" << std::endl;
}
void world()
{
std::cout << "world" << std::endl;
}
};
class B
{
public:
void receive(const A& a) {
a.sayhi();
}
};
class C
{
public:
void receive(const A& a) {
B b;
b.receive(a);
}
};
int main(int argc, char ** argv)
{
A a;
C c;
c.receive(a);
return 0;
}
错误:将“const A”作为“void A::hello()”的“this”参数传递会丢弃限定符[-fppermissive]
错误:将'const A'传递为'ullA::world()'的'this'参数会丢弃限定符[-fpermissive]
>
另一个选项是在调用hi
方法时使用const_cast,如下所示
A& ref = const_cast <A&>(a);
ref.hi();
您的hi
方法在您的A类中没有声明为const
。因此,编译器不能保证调用a.hi()
不会更改您对a
的常量引用,因此它会引发错误。
您可以在此处阅读有关常量成员函数的更多信息,以及const
关键字的正确用法。
我有与这里、这里或这里相同的问题,除了我为参数和函数设置了const: 但我有同样的编译错误:
在gcc 5.4.0上,从const C std::map获取条目时无法编译。 这看起来类似于传递“const”。此参数丢弃限定符[-fppermissive],它是关于
我将对象的引用传递给函数,并使用const表示它是只读方法,但如果我在该方法中调用另一个方法,即使我没有将引用作为参数传递,也会发生此错误。 错误:将'const A'传递为'valA::hello()'的'this'参数会丢弃限定符[-fpermissive] 错误:将“const A”作为“void A::world()”的“this”参数传递将丢弃限定符[-fpermissive]
下面是一个基本的代码片段,我得到了一个错误: 错误:传递'constd::map 注意:我知道我可以在不使用的情况下删除点,但上面的代码片段只是一个更大问题的示例。 我检查了一些关于类似错误的问题: 错误:传递constd::映射 但在这两种情况下,都是因为被声明为。另一方面,我试图使用/访问的
我有一个类缓存,它的函数write指定为 我这样调用这个函数。 上面的一行给了我以下错误 将“const Cache”作为“bool Cache::write(const MemoryAccess)”的“this”参数传递 this参数是特定于编译器的,它有助于代码混乱和中断本地命名空间变量优先级。但这样的变量并没有在这里传递。
代码如下(为简洁起见摘录): 颜色h: 颜色cpp: 我得到以下错误: 颜色cpp:16:29:错误:传递“const std::map” 错误指的是“返回颜色[cColortype];”在getColorText中。 我写这篇文章是为了一个类项目,我可以通过删除getColorText签名中的const声明来让它工作,但我正在尝试学习/采用良好的实践,并遵循建议,在不修改数据的成员函数中使用co