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

SmartPtr
本博客已搬至:http://www.cnblogs.com/baiyanhuang/
posts - 29,comments - 176,trackbacks - 0
By SmartPtr(http://www.shnenglu.com/SmartPtr/)

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

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

1 沒(méi)有在文件頭加#pragma once指示符。

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

//#pragma once
class Type
{  

};

Main.cpp:

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

 

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

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

#pragma once
class Type
{

};

 

#pragma once
class Type
{     

};

 

  這里main.cpp中同時(shí)包含了Type1.h, Type2.h兩個(gè)頭文件, 雖然其文件頭都有#pragma once,但因?yàn)槭遣煌奈募?/span> 預(yù)編譯器還是會(huì)兩次把Type類的定義放在Main.cpp中, 所以也會(huì)出現(xiàn)了重定義。

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

 

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

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

Type1.h:

#pragma once
class Type
{

};

Main.cpp:

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

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

    這里我們?cè)?/p>

4 D:\Test下打開(kāi)工程, 編譯, 出現(xiàn)類型Type重復(fù)定義錯(cuò)誤

這種情況下,main.cpp預(yù)編譯為:

Main.cpp:

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

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

  #pragma once

總結(jié)

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

因?yàn)樵谏源笠稽c(diǎn)的工程開(kāi)發(fā)中, 我們一般都會(huì)用虛擬盤來(lái)方便工作, 一是訪問(wèn)快捷,簡(jiǎn)化了路徑, 二是因?yàn)槎嗳藚f(xié)同開(kāi)發(fā),我們一般希望大家源代碼路徑相同,但我們不應(yīng)強(qiáng)制要求大家都把源代碼放死在某一目錄下, 這時(shí)把你放源代碼的路徑映射為一個(gè)虛擬盤(比如說(shuō)統(tǒng)一為X:)就能把大家的代碼路徑統(tǒng)一起來(lái)了。但是另一方面,有了虛擬盤, 就為出現(xiàn)類型重定義提供了條件, 以下是我得出的兩個(gè)解決方法:

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

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

#ifndef _XXX_H
#define _XXX_H
...

#endif

 

2 在包含頭文件時(shí),不要使用絕對(duì)路徑, 哪怕那是虛擬盤的絕對(duì)路徑。

posted on 2007-07-05 17:49 SmartPtr 閱讀(5870) 評(píng)論(5)  編輯 收藏 引用

FeedBack:
# re: C++中的類型重定義
2007-07-05 23:08 | cpper
學(xué)到了!!!!!  回復(fù)  更多評(píng)論
  
# re: C++中的類型重定義
2007-07-06 01:52 | 至尊拖鞋
見(jiàn)識(shí)了,還沒(méi)用過(guò)虛擬盤映射功能的  回復(fù)  更多評(píng)論
  
# re: C++中的類型重定義
2007-07-06 14:32 | william
也不一定用subst來(lái)做虛擬盤,如果是ntfs格式的話 其實(shí)做一個(gè)虛擬目錄比較好  回復(fù)  更多評(píng)論
  
# re: C++中的類型重定義
2007-07-08 01:32 | 天津大學(xué)計(jì)算機(jī)學(xué)院 常興龍
總結(jié)得很不錯(cuò),在Symbian開(kāi)發(fā)時(shí)會(huì)經(jīng)常用的虛擬路徑。  回復(fù)  更多評(píng)論
  
# re: C++中的類型重定義
2007-07-12 15:35 | Rick

VC是用MS自己的Compiler,估計(jì)這個(gè)Compiler是采用頭文件的絕對(duì)路徑來(lái)作為唯一標(biāo)識(shí)的,所以對(duì)于同一個(gè)文件通過(guò)不同的方式(本地和虛擬盤)來(lái)include,VC視作為兩個(gè)不同的頭文件。
而DevC++采用GCC的Compiler,這個(gè)Compiler發(fā)現(xiàn)兩個(gè)同名的頭文件(不管絕對(duì)路徑和這兩個(gè)文件是否其實(shí)是一個(gè)文件)被include后,會(huì)檢查這兩個(gè)頭文件的修改時(shí)間是否一致。如果一致,則認(rèn)為這兩個(gè)頭文件是一樣的,并且頭文件包含“#pragma once”的話就只解析一次,不會(huì)報(bào)錯(cuò)。否則,兩個(gè)文件修改時(shí)間不一樣,那會(huì)認(rèn)為是兩個(gè)不同的文件(不管這兩個(gè)文件的內(nèi)容是否一樣),所以解析的時(shí)候會(huì)報(bào)重復(fù)定義錯(cuò)誤。
  回復(fù)  更多評(píng)論
  

只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美午夜大胆人体| 亚洲精品在线看| 午夜久久电影网| 国产日韩欧美二区| 美女被久久久| 欧美a级大片| 亚洲乱码国产乱码精品精天堂 | 在线观看国产日韩| 欧美国产视频在线| 欧美日韩视频第一区| 欧美一区二区三区免费视频| 欧美一区二区三区精品| 在线看日韩av| 亚洲精品日本| 国产精品区一区二区三区| 久久全国免费视频| 欧美顶级大胆免费视频| 亚洲影音一区| 久久电影一区| 日韩午夜免费| 亚洲欧美大片| 亚洲欧洲一区二区在线播放| 一区二区三区久久久| 国内精品一区二区三区| 亚洲精品美女在线观看| 国产日韩欧美二区| 亚洲精品久久久久中文字幕欢迎你 | 欧美顶级大胆免费视频| 欧美体内she精视频在线观看| 久久狠狠一本精品综合网| 欧美插天视频在线播放| 欧美在线亚洲| 欧美精品一区在线观看| 久久婷婷久久一区二区三区| 欧美日韩中文字幕在线视频| 麻豆成人综合网| 国产精品yjizz| 亚洲国产精品激情在线观看| 国产午夜精品全部视频播放| 亚洲精品综合久久中文字幕| 国产亚洲综合在线| 亚洲一区二区三区四区五区黄| 亚洲国产精品福利| 欧美在线不卡| 欧美怡红院视频一区二区三区| 欧美激情第10页| 久久综合九色综合欧美就去吻| 欧美日韩免费高清一区色橹橹| 欧美成人资源| 在线观看欧美日韩| 欧美中文字幕久久| 欧美一级播放| 欧美日韩在线亚洲一区蜜芽| 欧美成人精品h版在线观看| 99re6这里只有精品| 欧美一区二区在线免费观看| 午夜一区二区三区不卡视频| 欧美日本精品| 91久久久国产精品| 日韩网站在线观看| 欧美成人精品一区二区三区| 玖玖视频精品| 黄色成人av网站| 性欧美暴力猛交69hd| 久久久国产精彩视频美女艺术照福利| 欧美亚一区二区| 99国产精品国产精品久久| 日韩小视频在线观看| 欧美国产精品人人做人人爱| 亚洲欧洲精品天堂一级| 亚洲美女免费视频| 欧美激情按摩| 中文亚洲字幕| 午夜精品一区二区三区在线| 国产日韩精品一区二区三区| 亚洲欧美电影院| 久久久久久久久久久久久女国产乱 | 欧美国产极速在线| 亚洲精品一二区| 欧美激情一区二区三区| 亚洲九九精品| 香蕉乱码成人久久天堂爱免费 | 美国成人直播| 亚洲国产天堂网精品网站| 在线视频亚洲一区| 国产精品日日摸夜夜添夜夜av| 午夜精品久久久久久久99樱桃| 久久久久久网站| 亚洲精品国产精品乱码不99按摩| 欧美日韩黄视频| 亚洲婷婷在线| 免费黄网站欧美| 亚洲天堂久久| 精品成人在线观看| 欧美日韩在线精品| 欧美在线视频网站| 亚洲日本欧美在线| 久久激情五月婷婷| 亚洲免费观看高清完整版在线观看| 欧美性片在线观看| 久久久亚洲精品一区二区三区| 亚洲精选久久| 美女999久久久精品视频| 亚洲一区二区三区高清不卡| 在线观看欧美| 国产精品久线观看视频| 欧美aaaaaaaa牛牛影院| 亚洲欧美乱综合| 亚洲日本中文字幕区| 老色批av在线精品| 午夜视频在线观看一区| 亚洲三级免费| 在线观看成人av电影| 国产精品免费观看视频| 欧美成人亚洲成人日韩成人| 欧美一区二区视频免费观看| 亚洲乱码日产精品bd| 欧美成人亚洲成人日韩成人| 久久精品道一区二区三区| 亚洲午夜av| 亚洲乱码国产乱码精品精98午夜| 狠狠色综合色区| 国产日韩精品一区二区浪潮av| 国产精品99一区| 香蕉久久夜色精品| 亚洲一区二区三区777| 亚洲啪啪91| 韩国欧美一区| 国产午夜精品在线| 国产美女精品视频| 国产精品久久久久久久app| 欧美日韩国产成人在线观看| 蜜臀久久99精品久久久久久9 | 欧美精品亚洲二区| 欧美精品一卡| 欧美日韩高清在线一区| 欧美久久精品午夜青青大伊人| 欧美国产一区二区在线观看| 欧美成人高清| 欧美成人资源网| 欧美精品偷拍| 欧美日韩在线不卡一区| 欧美视频在线观看免费网址| 欧美午夜一区二区三区免费大片 | 伊人色综合久久天天五月婷| 国产亚洲视频在线观看| 国产亚洲激情在线| 国语精品一区| 亚洲国产aⅴ天堂久久| 亚洲精品乱码久久久久久黑人 | 欧美色网一区二区| 国产精品午夜视频| 国产亚洲一区二区在线观看| 好吊一区二区三区| 亚洲激情小视频| 一区二区三区精品视频| 亚洲永久免费| 久久国产精品电影| 欧美aa国产视频| 亚洲激情视频在线播放| 99国产欧美久久久精品| 亚洲综合精品自拍| 久久精品视频免费观看| 暖暖成人免费视频| 国产精品99一区| 国内精品一区二区三区| 亚洲精品中文在线| 午夜久久99| 欧美 日韩 国产 一区| 亚洲免费成人| 久久黄色级2电影| 欧美精品亚洲一区二区在线播放| 国产精品女主播一区二区三区| 国产在线精品一区二区夜色| 亚洲精品影视在线观看| 欧美一区二区高清在线观看| 女女同性精品视频| 亚洲视频狠狠| 免费观看成人鲁鲁鲁鲁鲁视频| 国产精品久久久久久久一区探花| 伊人狠狠色j香婷婷综合| 一区二区欧美精品| 免费欧美视频| 亚洲午夜精品一区二区| 美女视频网站黄色亚洲| 国产精品综合网站| 99xxxx成人网| 麻豆精品视频在线| 亚洲一区二三| 欧美精品不卡| 在线成人黄色| 久久福利精品| av成人免费在线| 免费日韩成人| 国产一区免费视频| 亚洲欧美中文日韩v在线观看| 亚洲国产精品99久久久久久久久| 欧美在线免费| 国产精品一区二区三区免费观看| 亚洲国产成人porn|