国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

頭文件循環引用:如何破解這個編程死循環?

開發
在這趟奇妙的C++頭文件之旅中,我們一起探討了如何優雅地引入頭文件,就像在圖書館借書一樣簡單有趣。

嘿,讓我們來聊聊C++中那些可愛的頭文件引入方式吧! 

當我們在代碼中看到#include 時,你是否注意到它后面可以跟著兩種不同的"穿搭" —— 尖括號<> 和雙引號""??? 這可不是隨便選的哦!

想象一下,尖括號<> 就像是去圖書館借書 ??,系統會先去"公共書架"(編譯器的標準路徑)找,找不到再去"特藏室"(系統變量路徑)翻找。這種方式通常用來引入那些標準庫文件,比如我們常見的<iostream> 和<string> 。

而雙引號"" 則更像是在自己家里找書 ??,它會先在"書房"(當前文件目錄)翻找,找不到才會去"圖書館"(編譯器路徑和系統變量)借閱。這種方式主要用于我們自己編寫的頭文件,就像是我們自己的私人筆記本一樣。

頭文件引入小故事

來來來,讓我給你講個有趣的故事!想象一下,在C++的世界里,引入頭文件就像是在圖書館借書一樣有趣 ??

當我們需要標準庫的時候,就像去大圖書館的公共區域借書一樣 ???,我們會這樣寫:

#include <iostream>     // 借本輸入輸出的魔法書 ?
#include <string>       // 再來本字符串變變變 ??
#include <vector>       // 這本是動態數組的秘籍 ??
#include <algorithm>    // 最后來本算法寶典 ??

但是呢,有時候我們也需要用自己寫的"私房菜譜"(自定義頭文件)??,這時候就要用雙引號來"翻看"啦:

#include "MyClass.h"           // 就在書桌上的筆記本 ??
#include "utils/helpers.h"     // 放在工具箱里的說明書 ???
#include "../common/config.h"  // 樓上收藏的配置手冊 ??

看,是不是感覺頭文件引入也可以這么有趣呢??? 記住啦,標準庫就像公共圖書館的藏書,用尖括號<> 來借閱;而自己的小筆記就用雙引號"" 來翻看,就像在自己的書房里找書一樣方便!??

頭文件查找過程詳解

讓我們以#include <iostream> 為例,一起來探索編譯器是如何查找和引入頭文件的奇妙過程吧! ??

1. 使用尖括號<> 的查找過程 ??

當我們寫下#include <iostream> 時,編譯器會像偵探一樣按以下順序仔細查找 ???♂?:

(1) 標準庫目 ?? 編譯器在安裝時就預先配置了標準庫的搜索路徑。這些神奇的路徑是如何確定的呢?

a.編譯器安裝時的配置 ??

# GCC編譯器 ???
g++ -v -E -x c++ /dev/null

# Clang編譯器 ??
clang++ -v -E -x c++ /dev/null

b.默認搜索路徑 ???

# 在 Linux/Unix 系統中通常是: ??
/usr/include/c++/<版本號>      # C++標準庫頭文件 ??
/usr/local/include            # 本地安裝的庫文件 ??
/usr/include                  # 系統級別的頭文件 ??

# 在 Windows + MSVC 中通常是: ??
C:\Program Files (x86)\Microsoft Visual Studio\<版本>\<版本號>\VC\include

c.搜索順序的原理 

例如,當你包含<iostream> 時的實際過程:

#include <iostream>

// 1. 編譯器首先在內置緩存中找iostream
// 2. 如果沒找到,則在/usr/include/c++/<版本號>/iostream查找
// 3. 找到后,檢查是否已經被包含(通過頭文件保護符)
// 4. 如果是首次包含,則讀取并處理文件內容

當我們安裝C++編譯器時,安裝程序會自動設置標準庫的位置,這些位置被硬編碼到編譯器的配置文件中。

可以通過以下魔法咒語查看編譯器的搜索路徑:

  • 編譯器首先檢查內置的頭文件緩存(如果有的話) ??
  • 然后按照預定義的搜索路徑順序查找 ??
  • 最后查找環境變量指定的路徑 ??

(2) 為什么要使用這種搜索機制?

  • 安全性:系統頭文件存放在受保護的目錄中,防止意外修改
  • 統一性:所有項目都使用相同版本的標準庫,確保兼容性
  • 效率:預定義的搜索路徑可以加快文件查找速度
  • 維護性:系統升級時只需更新中央位置的文件

(3) 如何查看具體的頭文件內容?

# 在Linux系統中可以直接查看
cat /usr/include/c++/<版本號>/iostream

# 或者使用編譯器顯示預處理后的內容
g++ -E myfile.cpp | less

2. 使用雙引號"" 的查找過程 ??

以#include "myproject.h" 為例 ??:

  • 首先在當前源文件所在目錄查找 ??
// 如果源文件在 src/main.cpp
#include "myproject.h"  // 會先查找 src/myproject.h ??
  • 然后查找相對路徑 ???
// 在 src/main.cpp 中
#include "../include/myproject.h"  // 查找上級目錄的 include 文件夾 ??
  • 最后按照尖括號<> 的查找規則繼續查找 ??

頭文件引入的實際過程

讓我們看一個完整的例子 ??:

// main.cpp ??
#include <iostream>
#include "utils/math_helper.h"

int main() {
    // ...
}

預處理器處理這個文件的步驟 ??:

  • 展開<iostream> ??
// 1. 在標準庫路徑找到 iostream ??
// 2. 檢查是否已經包含(通過頭文件保護符)???
// 3. 展開內容,例如:?
namespace std {
    class ios_base { /*...*/ };  // 基礎輸入輸出類 ??
    class istream { /*...*/ };   // 輸入流類 ??
    // ...
}
  • 展開"utils/math_helper.h" ??
// 1. 先在當前目錄查找 utils/math_helper.h ??
// 2. 如果找不到,繼續在編譯器指定的路徑查找 ???
// 3. 展開內容 ??

項目實踐中的頭文件組織

在實際項目中,推薦這樣組織頭文件 ???:

project/ ?? ├── include/ # 公共頭文件目錄 ?? │ ├── project/ # 項目頭文件 ?? │ │ ├── core.h # 核心頭文件 ? │ │ └── utils.h # 工具頭文件 ??? │ └── third_party/ # 第三方庫頭文件 ?? ├── src/ # 源文件目錄 ?? │ ├── core.cpp # 核心實現 ?? │ └── utils.cpp # 工具實現 ?? └── CMakeLists.txt # CMake 構建文件 ???

使用時 ????:

// 在 src/core.cpp 中 ??
#include "project/core.h"    // 使用項目頭文件 ??
#include <algorithm>         // 使用標準庫 ??

所以下次當你在寫代碼時,記住這個簡單的規則 ??:

  • 系統的標準庫文件就用尖括號<> ??#include <iostream> ??
  • 自己寫的頭文件就用雙引號"" ??#include "myheader.h" ??

就是這么簡單又合理! ? 讓我們的代碼結構更清晰、更優雅! ??

頭文件循環引用:一個有趣的解決方案

嘿,小伙伴們!?? 今天讓我們來聊一個在 C++ 開發中經常遇到的"死循環"難題 ??

想象一下,就像兩個好朋友互相依賴的情況 ?? —— PersonA 想認識 PersonB,而 PersonB 也想認識 PersonA。在代碼世界里,這種情況可能會讓編譯器陷入混亂 ??

來看看這個有趣的例子:

// 文件:header1.h
#include "header2.h"
class PersonA {
private:
    PersonB* m_friend;  // 想和 PersonB 做朋友 ??
public:
    void sayHello();
};

// 文件:header2.h
#include "header1.h"
class PersonB {
private:
    PersonA* m_friend;  // 也想和 PersonA 做朋友 ??
public:
    void greet();
};

哎呀!這樣寫代碼就像兩個人互相追著對方的尾巴轉圈圈 ??,編譯器看到這種情況就會抓狂: "咦?要先編譯誰呢?" ??

不過別擔心!我們有一個聰明的解決方案 ? —— 就是使用"前向聲明"這個魔法咒語 ?? 告訴編譯器:"嘿,相信我,這個類待會兒就來!"

就像這樣改寫:

// 文件:header1.h
#ifndef HEADER1_H
#define HEADER1_H

class PersonB;  // 先說好:PersonB 待會兒就來!?
class PersonA {
    // ... 其他代碼保持不變 ...
};

#endif

這樣一來,我們的代碼就像一場優雅的舞會 ????,每個類都能找到自己的舞伴,編譯器也不會暈頭轉向啦!記住,有時候編程就像交朋友,不要太著急,慢慢來,總會遇到對的那個人(啊不,是類 ??)!

那如果不是指針引用呢?

有時候,我們可能會遇到需要直接引用對象而不是指針的情況:

// 文件:header1.h
#include "header2.h"
class PersonA {
private:
    PersonB m_friend;  // 想直接把朋友裝進口袋!??
public:
    void sayHello();
};

// 文件:header2.h
#include "header1.h"
class PersonB {
private:
    PersonA m_friend;  // 我也要把朋友裝進口袋!
public:
    void greet();
};

哎呀!這下可有意思了!?? 編譯器看到這段代碼時就像是在解一個"先有雞還是先有蛋"的問題 ????

為什么呢?讓我們來演一出小品:想象編譯器是一位可愛的搬家工人 ??

搬家工人:「嗯,讓我看看要搬的東西...PersonA類需要多大的空間呢?」 ?? 「哦,它里面有個PersonB,得先知道PersonB多大」 ?? 「那讓我看看PersonB...咦?它里面又有個PersonA?」 ?? 「但我還不知道PersonA多大啊...」 ?? 「但要知道PersonA多大,我得先知道PersonB多大...」 ?? 就這樣無限循環下去啦!

這就像是兩個小朋友互相說:"我要做一個和你一樣大的餅干!" "不,我要做一個和你的餅干一樣大的餅干!" ?? 最后誰也不知道該做多大的餅干才對!??

這就是為什么前向聲明在這種情況下幫不上忙 - 因為編譯器需要知道類的具體大小才能分配內存。用指針的話就不同啦,指針就像是一張藏寶圖 ???,大小是固定的,不管藏寶箱(對象)有多大!

所以下次如果你遇到這種情況,記得要么用指針(藏寶圖)???,要么用智能指針(帶GPS定位的藏寶圖)??,要么就得重新???計你的類結構咯!就像重新安排兩個小朋友的玩具收藏方式一樣!??

接口分離

不過別擔心,我們有個超棒的解決方案 - 接口分離!它就像是給小朋友們發了一張"交友名片"一樣 ??。這張名片上只寫著最重要的信息:"我會打招呼!",而不用把所有細節都告訴對方。

來看個具體的例子:

// 先設計一張可愛的交友名片 ??
class IFriend {
    virtual void sayHi() = 0;     // 我會說"嗨!" ??
    virtual void share() = 0;     // 我會分享玩具! ??
    virtual ~IFriend() = default; // 記得要好好說再見 ??
};

// 小明拿著這張名片來交朋友 ??
class XiaoMing : public IFriend {
    void sayHi() override { 
        std::cout << "嗨,我是小明!" << std::endl; 
    }
    void share() override {
        std::cout << "給你我的變形金剛!" << std::endl;
    }
};

// 小紅也想交朋友 ??
class XiaoHong {
private:
    IFriend& myFriend;  // 只需要知道對方有張交友名片就夠啦!
public:
    void playWith() {
        myFriend.sayHi();    // 和朋友打招呼 ??
        myFriend.share();    // 一起分享玩具 ??
    }
};

看!通過這種方式,小明和小紅就能愉快地玩耍了,完全不用擔心"我需要先認識你,還是你需要先認識我"這樣的煩惱 ??。這就是接口分離的魔力 ? - 它讓我們的代碼世界變得更簡單,更有趣!

記住啦,當你遇到循環引用的困擾時,就想想這個可愛的交友名片故事吧!讓代碼像小朋友們一樣,輕松快樂地交朋友!?? 這就是接口分離的精髓所在!??

總結

嘿,親愛的代碼冒險家們!?? 在這趟奇妙的C++頭文件之旅中,我們一起探討了如何優雅地引入頭文件,就像在圖書館借書一樣簡單有趣 ??。記住,標準庫文件就像公共圖書館的藏書,用尖括號<>來借閱,而自己的小筆記就用雙引號""來翻看,就像在自己的書房里找書一樣方便!??

當然啦,頭文件的循環引用就像兩個小朋友互相追著對方的尾巴轉圈圈 ??,但別擔心,我們有聰明的解決方案,比如用前向聲明這個魔法咒語 ??,或者用接口分離的交友名片 ??,讓代碼世界變得更簡單,更有趣!?

責任編輯:趙寧寧 來源: everystep
相關推薦

2024-12-04 09:47:26

C++頭文件實現類

2013-06-06 13:34:56

HashMap線程不安全

2018-10-10 20:20:14

2011-09-07 10:13:04

IPv6IPv4

2020-12-17 07:39:30

HashMap死循環數據

2025-01-21 00:00:00

HashMap死循環數據損壞

2010-04-26 13:30:21

服務器虛擬化

2020-09-29 15:24:07

面試數據結構Hashmap

2022-01-20 08:44:25

HashMap死循環開放性

2011-08-29 16:23:29

Lua腳本

2022-01-18 06:59:50

HashMap循環底層

2022-06-18 23:10:56

前端模塊循環依賴

2025-08-21 13:40:58

頭文件循環項目

2010-03-11 14:15:24

Python循環

2020-05-27 12:45:52

HashMapJava加載因子

2019-12-26 12:47:10

BashLinux命令

2017-05-04 20:15:51

iOSNSTimer循環引用

2021-10-27 07:15:36

Go 循環引用

2009-07-24 17:43:35

循環引用ASP.NET AJA

2023-01-31 08:24:55

HashMap死循環
點贊
收藏

51CTO技術棧公眾號

男男成人高潮片免费网站| 久久综合色8888| 久久av在线看| 久久精品蜜桃| 久久精品一区四区| 91大学生片黄在线观看| 影院欧美亚洲| 91精品视频一区| 清纯唯美亚洲经典中文字幕| 影音先锋日韩有码| 精精国产xxxx视频在线中文版 | 男男视频亚洲欧美| 久久精品久久精品国产大片| 中文字幕一区二区三区在线视频| 国产91在线播放| 国产一区二区在线视频你懂的| 日韩在线不卡视频| 国内欧美日韩| 色爱av美腿丝袜综合粉嫩av| 少妇一区视频| 久久香蕉国产线看观看网| 中文字幕日本一区| 九九精品视频在线观看| a级日韩大片| 秋霞av国产精品一区| 精品美女在线视频| 91免费综合在线| 亚洲小说区图片区| 国产伦精品一区二区三区视频孕妇 | 久久久久久999| 国产精品网址| 8050国产精品久久久久久| 牛牛精品成人免费视频| 欧美亚洲午夜视频在线观看| 尤物tv在线精品| 情事1991在线| 欧美在线首页| 欧美日韩亚洲在线| 国产一区二三区| 久久久久免费精品| 一区二区三区四区视频精品免费| 在线免费激情视频| 欧美一区二区不卡视频| www.成人影院| 午夜精品一区二区三区在线| 国产色综合天天综合网| 国产黄色片免费在线观看| 久久精品国产免费| 亚洲一区二区三区色| 懂色一区二区三区免费观看| 又粗又黑又大的吊av| 亚洲天天做日日做天天谢日日欢| 有码av在线| 欧美自拍偷拍一区| eeuss鲁一区二区三区| 日韩视频免费看| 免费欧美激情| 欧美一区亚洲二区| 99久久精品国产网站| 特黄特色大片免费视频大全| 欧美日韩亚洲综合在线| 一个人看的www视频在线免费观看 一个人www视频在线免费观看 | 亚洲国产另类久久精品| 国产aⅴ精品一区二区四区| 日本精品久久久久影院| 尤物在线精品| av网站手机在线观看| 亚洲人亚洲人成电影网站色| 午夜精品久久久久久久久久久久| 91精品在线看| 先锋a资源在线看亚洲| 伊人久久在线观看| 亚洲色大成网站www久久九九| 亚洲欧美视频一区二区| 色先锋资源久久综合5566| 美女网站一区| 欧美精品一区二区三区在线看午夜 | 97国产在线观看| 在线日本成人| 日韩网址在线观看| 欧美在线一二三| 麻豆一区在线| 精品免费国产| 亚洲三级电影全部在线观看高清| 91高清在线观看视频| 5566成人精品视频免费| 久久成人精品无人区| 在线视频尤物| 日韩亚洲国产中文字幕| 国产精品av久久久久久麻豆网| 妺妺窝人体色777777| 欧美性生活一区| 香蕉久久精品日日躁夜夜躁| 波多野结衣 作品| 欧美日韩一区二区在线观看视频 | 国产精品波多野结衣| 欧美日韩激情小视频| 欧美黄色一级| 麻豆传媒网站在线观看| 一本大道久久a久久精品综合| 成人污污视频| 中文字幕免费高| 欧美美女网站色| 国产一区二区三区探花 | 欧美激情xxxx| 国内不卡的二区三区中文字幕 | 不卡av免费在线观看| v片在线观看| 成人福利视频在线观看| 久久久99精品久久| 国产高清自产拍av在线| 精品蜜桃一区二区三区| 精品久久久国产| 任你弄精品视频免费观看| 成人免费aaa| 亚洲精品自在久久| 天堂久久一区二区三区| 永久免费av在线| 91久久极品少妇xxxxⅹ软件| 亚洲一区av在线| 亚州综合一区| 午夜宅男在线视频| 久久精品夜夜夜夜夜久久| 国产伦精品一区二区三区免费 | 成人免费在线看片| 伊人性伊人情综合网| 国产精品videossex| 被灌满精子的波多野结衣| 亚洲精品国产精品国自产在线| 国产农村妇女精品一区二区| av在线免费观看网| 国产伦精品一区二区三区照片| 疯狂蹂躏欧美一区二区精品| 日韩精品免费| 四虎影院在线域名免费观看| 国产噜噜噜噜噜久久久久久久久| 亚洲精品va在线观看| 欧美综合一区| 伊人影院在线播放| 不卡一卡2卡3卡4卡精品在| 欧美自拍偷拍一区| 国产精品美女久久久| av人人综合网| 久久手机在线视频| 欧美另类xxx| 亚洲美女区一区| 91精品啪在线观看国产18| 黄色在线网站| 久精品国产欧美| 亚洲成人国产精品| 成av人片一区二区| 国产精品一区免费在线| 亚洲一区二区三区四区五区xx| 欧美孕妇性xx| 91福利在线看| 国内精品免费在线观看| 日韩成人在线电影| 嫩草影院永久入口| 国产精品一区二区三区在线观| 欧美成人一区二区三区在线观看| 久久99精品一区二区三区三区| 日韩精品一区二区三区| 欧在线一二三四区| 国产久一一精品| 欧美日本一道本| 成人免费福利片| 宅男在线一区| 国产在线观看av| 国产精品自拍片| 国产精品中文字幕在线| 日韩三级视频在线观看| 成人黄色小视频在线观看| 伊甸园亚洲一区| 国精产品一区| 久久精品99国产| 91久久精品国产91久久性色tv| 精品裸体舞一区二区三区| 久久综合资源网| 久久久久久免费视频| caoporn-草棚在线视频最| 欧美成人免费高清视频| 91网免费观看| 在线观看日韩欧美| 亚洲国产日韩综合久久精品| 奇米四色…亚洲| 日韩高清电影免费| 日皮视频在线观看| 成人高清在线观看免费| 伊人久久大香线蕉午夜av| 欧美中文字幕精品| 亚洲国产欧美久久| 亚洲男人天堂一区| 精品一区二区三区影院在线午夜| 欧美亚视频在线中文字幕免费| 超碰在线最新| 黄a大片av永久免费| 日本丰满大乳奶| 亚洲综合中文字幕在线| 久久久精品免费| 日韩欧美国产高清|