友元函数报错“未定义标识符”、“找不到标识符”

错误代码如下所示

#include 

class A{

public:
    friend void fun(A a){std::cout << "Im here" << std::endl;}
    friend void fun2(){ std::cout << "Im here2" << std::endl; }
    friend void fun3();
};

void fun3(){
    std::cout << "Im here3" << std::endl;
}

int main() 
{  
    fun(A()); //运行正常
    //fun2(); 报错: 'fun2' 找不到标识符、标识符未定义
    fun3(); // 运行正常
} 

错误原因:

虽然函数 fun2 确实定义了一个函数,且为友元函数,但是在全局作用域(global scope)中它未被声明,因此main函数中调用fun2时程序不知道fun2存在于哪里。

但fun函数能运行的原因是参数依赖性检查接手了函数在全局作用域声明的工作,因为fun函数带有一个类A 的参数。

正确代码:

更正方法①

class A {
   friend void fun(A a);
   friend void fun2();
   friend void fun3();
};

void fun(A a) { std::cout << "I'm here"  << std::endl; }
void fun2()   { std::cout << "I'm here2" << std::endl; }
void fun3(){
    std::cout << "Im here3" << std::endl;
}
int main() 
{  
    fun(A());
    fun2();
    fun3();
} 

更正方法②:(添加函数在全局作用域的声明)

class A {
    friend void fun(A a){std::cout << "Im here" << std::endl;}
    friend void fun2(){ std::cout << "Im here2" << std::endl; }
    friend void fun3();
};

void fun2();
void fun3(){
    std::cout << "Im here3" << std::endl;
}
int main() 
{  
    fun(A());
    fun2();
    fun3();
} 

你可能感兴趣的:(c++)