青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

yutou's blog

請不要做浮躁的人,請熱愛C++。
posts - 14, comments - 1, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

C++中的類型重定義

Posted on 2008-03-10 16:32 yutou 閱讀(495) 評論(0)  編輯 收藏 引用 所屬分類: Programming
By SmartPtr(http://m.shnenglu.com/SmartPtr/)

這幾天工作時碰到一個C++的編譯錯誤(我使用的是Visual C++ 7.0),說是有一個類重復定義,仔細想想我們的這個項目也是做了好幾個Release了, 內部代碼應該不會有這樣的低級錯誤, 真把類型給重復定義了,檢查結果正如我預料的一樣。 就這樣, 我左右沒找到原因,被一個編譯錯誤給卡在那里了。(在我的概念中, 程序錯誤的等級為:編譯錯誤->鏈接錯誤->邏輯錯誤, 此錯誤屬于最低級 )。這時我仔細看了一下錯誤提示, 發現重復定義是由于從兩個不同的路徑包含了同一個頭文件而引起的,同事也建議從另外一個路徑打開工程試試, 這才慢慢發現了原因。這個原因可能有些拗口,而事實上要出現這種錯誤也有些曲折 讓我從不同情況下的類型重定義來解釋一下吧。

我總結的C++中類型重定義情況有三。

1 沒有在文件頭加#pragma once指示符。

Type1.h:  #pragma once的作用是保證本文件只被編譯一次,如果沒有在Type1.h中加這句話那么在main.cpp里面包含了兩次Type1.h, 就相當于在main.cpp里面定義了兩次Type類, 自然就是類型重定義了。

//#pragma once
class Type
{
}
;

Main.cpp:
#include "Type1.h"
#include 
"Type1.h"
int main(int argc, char *argv[])
{
   
return 1;
}

2 兩個不同的頭文件中定義了相同的類型(均有#pragma once

Type1.h:Type2.h:Main.cpp:

#pragma once
class Type
{

}
;


#pragma once
class Type
{     

}
;


這里main.cpp中同時包含了Type1.h, Type2.h兩個頭文件, 雖然其文件頭都有#pragma once,但因為是不同的文件, 預編譯器還是會兩次把Type類的定義放在Main.cpp中, 所以也會出現了重定義。

#include "Type1.h"
#include 
"Type2.h"
int main(int argc, char *argv[])
{
   
return 1;
}


3 從兩個不同的路徑包含了同一個頭文件

  前面兩種是比較常見, 也是比較容易解決的情況, 而這里要講的第三種情況, 比較少見, 而且一般出現在有虛擬映射盤的時候。(這樣才能做到從兩個不同的路徑包含同一個頭文件), 其他會在什么時候出現, 我還沒想到, 知道的朋友頂一下:)。下面我來分析一下:
1 VC工程在D:\Test目錄下。
2 映射虛擬盤XD:\Test.
不熟悉的網友可以按此操作: 開始->運行->在運行窗口輸入:cmd->cmd窗口輸入:
Subst X: D:\Test->回車。
3 該工程有文件Type1.h, main.cpp

Type1.h:

#pragma once
class Type
{

}
;

Main.cpp:

main.cpp這樣包含了兩個頭文件, 從本質上來講, 它們都對應于物理盤D:\Test下的文件Type1.h, 是同一個文件。但在不同的操作下, VC對其有不同的解釋。#include "X:\Type1.h"用的是絕對路徑, 自然沒有什么異議, #include "Type1.h"卻有些變化:
*假如我從D:\Test\下打開工程, 那么#include "Type1.h"其實就是#include "D:\Test\Type1.h"
*假如從X:\下打開工程,那么#include "Type1.h"就解釋為#include "X:\Type1.h"

#include "Type1.h"
#include 
"X:Type1.h"
int main(int argc, char *argv[])
{
   
return 1;
}

這里我們在

4 D:\Test下打開工程, 編譯, 出現類型Type重復定義錯誤

這種情況下,main.cpp預編譯為:

Main.cpp:

只保證本文件被編譯一次, 這里VC將其認為是兩個不同的文件, 所以都要編譯, 出現編譯錯誤自然也就不奇怪了。
   
當然, 這里如果從X:\ 下打開工程的話,VC就會認為都是從X:\Type1.h下包含這個文件,#pragma once起到了作用, 也就不會出現類型重定義了

#include "D:TestType1.h"
#include 
"X:Type1.h"
int main(int argc, char *argv[])
{
   
return 1;
}

 

#pragma once

總結

我在VC7, VC8,Dev C++中都測試了第三種情況, 發現只有Dev C++是可以通過編譯的。這可能是微軟VC#pragma once還不夠智能吧,輕易的被Windows的虛擬盤給蒙蔽了雙眼, 看不到其本質(只是猜測, 或許VC這么處理是有其他用意的)。

因為在稍大一點的工程開發中, 我們一般都會用虛擬盤來方便工作, 一是訪問快捷,簡化了路徑, 二是因為多人協同開發,我們一般希望大家源代碼路徑相同,但我們不應強制要求大家都把源代碼放死在某一目錄下, 這時把你放源代碼的路徑映射為一個虛擬盤(比如說統一為X:)就能把大家的代碼路徑統一起來了。但是另一方面,有了虛擬盤, 就為出現類型重定義提供了條件, 以下是我得出的兩個解決方法:

1
拋棄#pragma once使用古老但集穩定性與移植性于一身的

來保證頭文件只被編譯一次。這樣不管是包含兩個相同的文件,還是包含兩個不同的文件,或是包兩個文件相同但路徑不同的文件, 只要_XXX_H被定義過, 就不會再編譯那個編譯(但這里我們要保證_XXX_H的唯一性, 如果兩個不同的頭文件里用了同一_XXX_H,是會出問題的)

 

#ifndef _XXX_H
#define _XXX_H


#endif

2 在包含頭文件時,不要使用絕對路徑, 哪怕那是虛擬盤的絕對路徑。
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产精品护士白丝一区av| 亚洲欧美在线看| 亚洲一卡二卡三卡四卡五卡| 亚洲激情啪啪| 99国产精品一区| 亚洲资源av| 久久久91精品| 亚洲福利国产精品| 亚洲茄子视频| 亚洲影院色无极综合| 午夜精品久久久久99热蜜桃导演| 欧美一区二区三区电影在线观看| 久久天天狠狠| 欧美视频在线观看一区| 国产亚洲福利| aaa亚洲精品一二三区| 亚洲午夜极品| 久久中文精品| 一区二区精品国产| 猫咪成人在线观看| 国产精品爽爽ⅴa在线观看| 伊人久久大香线蕉av超碰演员| 亚洲另类自拍| 久久在线观看视频| 一区二区三区产品免费精品久久75| 亚洲制服丝袜在线| 免费亚洲一区二区| 国产精品网站在线| 日韩亚洲欧美在线观看| 久久精品一二三区| 日韩视频一区二区| 免费人成精品欧美精品| 国产精品视频免费在线观看| 亚洲国产精品高清久久久| 久久丁香综合五月国产三级网站| 夜夜嗨av一区二区三区四季av| 午夜精品久久久久影视 | 久久―日本道色综合久久| 欧美日韩成人一区二区| 国产午夜精品一区二区三区欧美| 日韩午夜在线观看视频| 老司机一区二区| 午夜精品久久久久久久久| 欧美三级视频在线| 亚洲激情一区| 欧美jizz19性欧美| 久久精品国产精品 | 鲁大师影院一区二区三区| 亚洲午夜激情在线| 欧美亚一区二区| 中文日韩在线| 亚洲日韩欧美视频一区| 免费成人黄色| 亚洲精品日韩激情在线电影| 久久综合久久综合九色| 欧美在线日韩精品| 国产亚洲电影| 久久久噜噜噜久久久| 先锋影音国产精品| 国产亚洲精品资源在线26u| 久久国产88| 久久精品国产91精品亚洲| 国内精品久久久久影院 日本资源| 性欧美大战久久久久久久免费观看| aⅴ色国产欧美| 国产精品高清免费在线观看| 亚洲免费一级电影| 亚洲欧美精品中文字幕在线| 国产伦精品一区二区三区视频孕妇 | 亚洲电影有码| 亚洲国产1区| 欧美日韩国产一区二区| 亚洲欧美另类中文字幕| 午夜精品一区二区三区在线播放| 国产美女精品视频| 六十路精品视频| 欧美精品久久一区二区| 亚洲午夜视频在线| 亚洲欧洲av一区二区三区久久| 国产真实乱偷精品视频免| 久久亚洲欧美| 欧美精品日韩综合在线| 亚洲在线免费| 久久国产婷婷国产香蕉| 91久久一区二区| 国产精品99久久久久久久久久久久| 鲁鲁狠狠狠7777一区二区| 亚洲成人在线视频播放| 亚洲盗摄视频| 国产精品a级| 免费日韩成人| 国产精品五区| 亚洲精品资源| 国产一区二区三区久久 | 亚洲一区二区三区在线| 日韩一区二区电影网| 亚洲精品久久久一区二区三区| 亚洲三级免费电影| 亚洲精品视频二区| 亚洲男女毛片无遮挡| 一本色道久久加勒比88综合| 亚洲欧美日韩综合aⅴ视频| 久久久久久久一区| 国产亚洲成年网址在线观看| 一区二区成人精品 | 亚洲国产另类久久久精品极度| 美女在线一区二区| 午夜精品久久| 欧美激情va永久在线播放| 亚洲欧美一区二区激情| 欧美sm视频| 久久久久久夜精品精品免费| 欧美日韩国产大片| 免费亚洲一区| 国产一区二区主播在线| 亚洲高清网站| 久久综合中文| 国产精品久久久久77777| 欧美激情一区二区三区在线| 国产精品一区免费观看| 亚洲美女av黄| 亚洲日本电影| 蜜桃av噜噜一区二区三区| 久久久噜噜噜久久中文字幕色伊伊| 欧美三级网址| 99riav1国产精品视频| 亚洲精品中文在线| 久久蜜桃香蕉精品一区二区三区| 午夜精品电影| 国产精品三级久久久久久电影| 亚洲精品裸体| 一本色道久久综合狠狠躁篇怎么玩 | 一区二区三区精品视频在线观看| 久久婷婷激情| 美女在线一区二区| 影音欧美亚洲| 女人天堂亚洲aⅴ在线观看| 免费亚洲视频| 亚洲乱码国产乱码精品精可以看| 欧美xart系列在线观看| 亚洲全黄一级网站| 亚洲手机视频| 国产目拍亚洲精品99久久精品 | 欧美成人免费播放| 91久久精品www人人做人人爽 | 国产专区欧美专区| 久久亚洲精品网站| 亚洲盗摄视频| 夜夜嗨av一区二区三区网页| 欧美精品久久一区| 亚洲图中文字幕| 久久精品伊人| 1024日韩| 欧美日韩免费| 欧美一级久久久| 亚洲第一精品福利| 国产精品99久久久久久久vr| 国产精品入口66mio| 久久九九电影| 日韩视频免费| 久久精品五月| 亚洲精品欧洲| 国产日韩1区| 欧美成人tv| 亚洲欧美区自拍先锋| 巨胸喷奶水www久久久免费动漫| 亚洲人精品午夜在线观看| 欧美午夜精品一区二区三区| 欧美在线视频不卡| 亚洲国产精品一区二区三区| 亚洲欧美视频在线观看| 亚洲国产二区| 国产精品系列在线| 欧美国产精品人人做人人爱| 亚洲综合视频在线| 亚洲国产高清一区| 欧美尤物一区| 免费亚洲电影| 日韩视频在线播放| 国产精品一卡二卡| 欧美 日韩 国产 一区| 亚洲一区区二区| 亚洲国产婷婷| 蜜桃av综合| 久久久国产精品亚洲一区 | 亚洲最快最全在线视频| 国产欧美婷婷中文| 欧美区二区三区| 蜜臀91精品一区二区三区| 亚洲自拍偷拍色片视频| 最近中文字幕mv在线一区二区三区四区| 久久成人精品无人区| 亚洲桃色在线一区| 亚洲经典视频在线观看| 国产综合久久| 国产日韩欧美二区| 国产精品爽黄69| 国产精品日韩精品欧美在线| 欧美日韩国产免费观看| 老牛影视一区二区三区|