C++ 前置聲明詳解及實(shí)例
C++ 前置聲明詳解及實(shí)例
【1】一般的前置函數(shù)聲明
見過最多的前置函數(shù)聲明,基本格式代碼如下:
#include <iostream>
using namespace std;
void fun(char ch, int *pValue, double dValue);
void main()
{
int nValue = 100;
double dValue = 111.22;
fun('a', &nValue, dValue);
system("pause");
}
void fun(char ch, int *pValue, double dValue)
{
return;
}
很好理解,不做贅述。
【2】自定義類型的前置聲明
自定義類型的前置聲明,由于編譯器不知道類型的大小,所以不可以聲明類型的對(duì)象。只可以利用類型聲明指針和引用。
代碼如下:
/*
* 自定義類型前置聲明
*/
#include <iostream>
using namespace std;
class B;
class A
{
private:
// 內(nèi)置類型
int m_nInt;
int& m_nRInt;
int* m_pInt;
// 自定義類型
// B b; // error!
B* m_pB;
B& m_b;
public:
A (B *pBPara = NULL) : m_nInt(100)
, m_nRInt(m_nInt)
, m_pInt(NULL)
, m_pB(NULL)
, m_b((NULL == pBPara) ? (*m_pB) : (*pBPara))
{
cout << "A()" << endl;
}
~A()
{
cout << "~A()" << endl;
}
void funA()
{
// m_pB->doAnything(); // build error C2027: use of undefined type 'B'
}
};
class B
{
private:
int m_n;
public:
B (int n = 100) : m_n(n)
{
cout << "B()" << endl;
}
~B()
{
cout << "~B()" << endl;
}
void doAnything()
{
cout << "B::anythig()" << endl;
}
};
void main()
{
A objA;
system("pause");
}
如上,利用前置類型的指針想調(diào)用其成員函數(shù),會(huì)報(bào)編譯錯(cuò)誤!那么,腫么辦?請(qǐng)看下文。
【3】聲明和實(shí)現(xiàn)分離
代碼如下,聲明頭文件:
/*
* TestForwardDeclar.h
*/
#ifndef D_TESTFORWARDDECLAR_H_
#define D_TESTFORWARDDECLAR_H_
#include <iostream>
class B; // 前置聲明自定義類型
class A
{
private:
// 內(nèi)置類型
int m_nInt;
int& m_nRInt;
int* m_pInt;
// 自定義類型
// B b; // error!
B* m_pB;
B& m_b;
public:
A (B *pBPara = NULL);
~A ();
void funA();
};
class B
{
private:
int m_n;
public:
B (int n = 100);
~B ();
void doAnything();
};
#endif
代碼如下,定義文件:
/*
* TestForwardDeclar.cpp
*/
#include "TestForwardDeclar.h"
#include <iostream>
A::A (B *pBPara)
: m_nInt(100)
, m_nRInt(m_nInt)
, m_pInt(NULL)
, m_pB(NULL)
, m_b((NULL == pBPara) ? (*m_pB) : (*pBPara))
{
std::cout << "A()" << std::endl;
}
A::~A()
{
std::cout << "~A()" << std::endl;
}
void A::funA()
{
m_pB->doAnything(); // 分開頭文件和實(shí)現(xiàn)文件即可
}
B::B (int n) : m_n(n)
{
std::cout << "B()" << std::endl;
}
B::~B()
{
std::cout << "~B()" << std::endl;
}
void B::doAnything()
{
std::cout << "B::anythig()" << std::endl;
}
代碼如下:測(cè)試文件:
#include "TestForwardDeclar.h"
void main()
{
A objA;
}
編譯成功,運(yùn)行結(jié)果是期望效果。
【4】總結(jié)
自定義類型前置聲明時(shí),只可以利用類型名聲明指針和引用變量(謹(jǐn)記不可以聲明對(duì)象或new 對(duì)象,均因?yàn)轭愋痛笮〔淮_定,編譯器無能為力)。
若需要利用指針或引用調(diào)用前置類型的接口,必須按照聲明和實(shí)現(xiàn)分離的方式進(jìn)行編碼。
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
相關(guān)文章
dev-c++創(chuàng)建lib(靜態(tài)鏈接庫(kù))文件的實(shí)現(xiàn)步驟
本文主要介紹了dev-c++創(chuàng)建lib(靜態(tài)鏈接庫(kù))文件的實(shí)現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06
C++實(shí)現(xiàn)LeetCode(67.二進(jìn)制數(shù)相加)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(67.二進(jìn)制數(shù)相加),本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07
C++ boost::asio編程-異步TCP詳解及實(shí)例代碼
這篇文章主要介紹了C++ boost::asio編程-異步TCP詳解及實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下2016-11-11

