[英]C++ namespace errors
我正在Windows 7 Pro 64位上運行mingw-w64。
在命名空間中嘗試代碼時遇到錯誤,但是在沒有命名空間的情況下可以正常工作。 代碼是:
//foo.h
#ifndef FOO_H
#define FOO_H
namespace joke {
extern "C" int fooStack[10];
extern "C" int *fooPtr;
extern "C" void fooInit();
extern "C" void fooPush(int iVar);
extern "C" int fooPop();
}
#endif // FOO_H
// foo.cpp
#include "foo.h"
using namespace joke;
int fooStack[10];
int *fooPtr;
void fooInit() {
fooPtr = &fooStack[0] + 9;
}
void fooPush(int iVar) {
*fooPtr = iVar;
fooPtr -= 1;
}
int fooPop() {
int oVar;
fooPtr += 1;
oVar = *fooPtr;
}
// bar.cpp
#include <iostream>
#include "foo.h"
using namespace std;
using namespace joke;
int inVar = 0;
int outVar = 0;
void Report() {
int i;
cout << "Pointer: " << fooPtr << endl;
cout << "Stack: ";
for (i = 0; i < 10; i++) {
cout << fooStack[i] << " ";
}
cout << endl;
cout << "inVar: " << inVar << endl;
cout << "outVar: " << outVar << endl << endl;
}
int main() {
int i;
fooInit();
cout << endl;
cout << "Initializing" << endl;
Report();
for (i = 0; i < 8; i++) {
inVar = (i * 34) + 34;
cout << "set inVar" << endl;
Report();
fooPush(inVar);
cout << "Push inVar" << endl;
Report();
}
for (i = 0; i < 8; i++) {
outVar = fooPop();
cout << "Pop outVar" << endl;
Report();
}
return 0;
}
生成文件:
all:
g++ -S foo.cpp
g++ -S bar.cpp
g++ -c foo.s
g++ -c bar.s
g++ -o FB foo.o bar.o
正如我說的,如果刪除或注釋掉了命名空間規范,那么一切都可以正常工作。 使用命名空間規范后,結果為:
c:\work\gccWork\FooTest>make
g++ -S foo.cpp
foo.cpp: In function 'void fooInit()':
foo.cpp:11:2: error: reference to 'fooPtr' is ambiguous
fooPtr = &fooStack[0] + 9;
^
foo.cpp:8:6: note: candidates are: int* fooPtr
int *fooPtr;
^
In file included from foo.cpp:3:0:
foo.h:9:18: note: int* joke::fooPtr
extern "C" int *fooPtr;
^
foo.cpp:11:12: error: reference to 'fooStack' is ambiguous
fooPtr = &fooStack[0] + 9;
^
foo.cpp:7:5: note: candidates are: int fooStack [10]
int fooStack[10];
^
In file included from foo.cpp:3:0:
foo.h:8:17: note: int joke::fooStack [10]
extern "C" int fooStack[10];
^
foo.cpp: In function 'void fooPush(int)':
foo.cpp:15:3: error: reference to 'fooPtr' is ambiguous
*fooPtr = iVar;
^
foo.cpp:8:6: note: candidates are: int* fooPtr
int *fooPtr;
^
In file included from foo.cpp:3:0:
foo.h:9:18: note: int* joke::fooPtr
extern "C" int *fooPtr;
^
foo.cpp:16:2: error: reference to 'fooPtr' is ambiguous
fooPtr -= 1;
^
foo.cpp:8:6: note: candidates are: int* fooPtr
int *fooPtr;
^
In file included from foo.cpp:3:0:
foo.h:9:18: note: int* joke::fooPtr
extern "C" int *fooPtr;
^
foo.cpp: In function 'int fooPop()':
foo.cpp:21:2: error: reference to 'fooPtr' is ambiguous
fooPtr += 1;
^
foo.cpp:8:6: note: candidates are: int* fooPtr
int *fooPtr;
^
In file included from foo.cpp:3:0:
foo.h:9:18: note: int* joke::fooPtr
extern "C" int *fooPtr;
^
foo.cpp:22:10: error: reference to 'fooPtr' is ambiguous
oVar = *fooPtr;
^
foo.cpp:8:6: note: candidates are: int* fooPtr
int *fooPtr;
^
In file included from foo.cpp:3:0:
foo.h:9:18: note: int* joke::fooPtr
extern "C" int *fooPtr;
^
make: *** [all] Error 1
我瀏覽了各種C ++教科書和參考資料,以及在線的一些參考資料和論壇。 我認為語法沒有任何問題。
我想念什么?
您正在要求C鏈接。 但是C沒有命名空間概念。 對我而言,這似乎是利益沖突。
fooPtr
在全局(在未namespace
)和namespace joke
。 他們是不同的實體。
然后, using namespace joke
告訴編譯器將joke
名稱用作候選者以匹配標識符
當代碼具有語句fooPtr = &fooStack[0] + 9
時,編譯器可以看到名稱::fooPtr
和joke::fooPtr
。 using namespace joke
意味着::fooPtr
和joke::fooPtr
都是有效的匹配項。 沒有理由偏愛一個,因此編譯器由於含糊不清而拒絕了該代碼。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.