1

我想知道是什么导致我的代码中出现双重定义链接器错误。这让我感到困惑,因为似乎没有任何理由。我认为我不会在会导致这种情况的地方添加#include任何文件,因为我的文件是线性结构的。.h#include

需要明确的是,我不是在问错误是什么意思,我是在问我的代码中是什么导致了它。我已经在这个网站(和其他网站)上研究了它的含义,但在我的代码中找不到与可能导致它的原因相关的答案。

顺便说一句,我正在使用 Visual Studio 2017

以下是错误:

1>ObjectHandler.cpp

1>Main.cpp

1>Generating Code...

1>ObjectHandler.obj : error LNK2005: "void __cdecl pixelsInit(void)" (?
pixelsInit@@YAXXZ) already defined in Main.obj

1>ObjectHandler.obj : error LNK2005: "void __cdecl pixelsUpdate(void)" (?
pixelsUpdate@@YAXXZ) already defined in Main.obj

1>ObjectHandler.obj : error LNK2005: "void __cdecl spritesInit(void)" (?
spritesInit@@YAXXZ) already defined in Main.obj

1>ObjectHandler.obj : error LNK2005: "void __cdecl spritesUpdate(void)" (?
spritesUpdate@@YAXXZ) already defined in Main.obj

1>ObjectHandler.obj : error LNK2005: "class std::vector<struct pixel,class 
std::allocator<struct pixel> > pixels" (?pixels@@3V?$vector@Upixel@@V?
$allocator@Upixel@@@std@@@std@@A) already defined in Main.obj

1>ObjectHandler.obj : error LNK2005: "class std::map<class 
std::basic_string<char,struct std::char_traits<char>,class 
std::allocator<char> >,struct sprite,struct std::less<class 
std::basic_string<char,struct std::char_traits<char>,class 
std::allocator<char> > >,class std::allocator<struct std::pair<class 
std::basic_string<char,struct std::char_traits<char>,class 
std::allocator<char> > const ,struct sprite> > > sprites" (?sprites@@3V?
$map@V?$basic_string@DU?$char_traits@D@std@@V?
$allocator@D@2@@std@@Usprite@@U?$less@V?$basic_string@DU?
$char_traits@D@std@@V?$allocator@D@2@@std@@@2@V?$allocator@U?$pair@$$CBV?
$basic_string@DU?$char_traits@D@std@@V?
$allocator@D@2@@std@@Usprite@@@std@@@2@@std@@A) already defined in Main.obj

1>fatal error LNK1169: one or more multiply defined symbols found

这是我的代码结构:

简单类型.h:

#pragma once

struct loc {

    int x;
    int y;
    int d;
    int s;

};

struct color {

    _int8 r;
    _int8 g;
    _int8 b;
    _int8 a;

};

复杂类型.h:

#pragma once
#include "SimpleTypes.h"
#include <string>

struct pixel {

    loc pos;

    color col;

};

struct sprite {

    std::string name;

    std::string file;

    loc pos;

};

对象处理程序.cpp:

#include "ComplexTypes.h"
#include <string>
#include <map>
#include <vector>

std::vector<pixel> pixels;
std::map<std::string, sprite> sprites;

void pixelsInit(){};

void spritesInit(){};

void pixelsUpdate(){};

void spritesUpdate(){};

主文件

#include "ObjectHandler.cpp"

int main() {

    pixelsInit();
    spritesInit();

    while (true) {

        pixelsUpdate();
        spritesUpdate();

    };

    return 0;
}
4

1 回答 1

2

在您的项目中,您正在编译ObjectHandler.cpp为一个独立的翻译单元。同时,您还包括ObjectHandler.cppMain.cpp其作为Main.cpp.

因此,ObjectHandler.cpp在您的程序中定义的所有内容都会被定义两次。因此出现错误。

问题是:你为什么要ObjectHandler.cpp加入Main.cpp?你试图达到什么目的?

如果您出于某种非正统的原因,真的想要/必须将其作为 的一部分包含并编译ObjectHandler.cpp,那么同时停止编译为独立的翻译单元。Main.cppMain.cppObjectHandler.cpp

同时,在这种情况下,更传统的方法是ObjectHandler.h为您的ObjectHandler.cpp. 就像是

#pragma once
#include "ComplexTypes.h"
#include <string>
#include <map>
#include <vector>

extern std::vector<pixel> pixels;
extern std::map<std::string, sprite> sprites;

void pixelsInit();
void spritesInit();
void pixelsUpdate();
void spritesUpdate();

并将其包含在其中Main.cpp

ObjectHandler.cpp可能如下所示

#include "ObjectHandler.h"

std::vector<pixel> pixels;
std::map<std::string, sprite> sprites;

void pixelsInit(){}
void spritesInit(){}
void pixelsUpdate(){}
void spritesUpdate(){}

注意重要的细节:.h文件只包含声明(函数没有主体,对象用 声明extern),而.cpp文件包含定义(函数有主体,对象没有声明extern

于 2018-01-07T01:44:00.020 回答