gpt4 book ai didi

c++ - 链接器因重复符号而失败

转载 作者:太空宇宙 更新时间:2023-11-04 16:19:43 25 4
gpt4 key购买 nike

使用下面的代码,当我尝试编译时

clang++ -std=c++11 -stdlib=libc++ -o test sales_function.cpp sales_prog.cpp 

出现以下错误

duplicate symbol __ZN10Sales_data7combineERKS_ in:
/var/folders/7f/9r4z5bs90bjfm3dy1k_g03xc0000gn/T/sales_functions-5G1FRA.o
/var/folders/7f/9r4z5bs90bjfm3dy1k_g03xc0000gn/T/sales_prog-82wDRv.o
ld: 1 duplicate symbol for architecture x86_64
clang: error: linker command failed with exit code 1 (use -v to see invocation)

现在为了使文件 sales_functions.cpp 中的非成员函数起作用,我包含了“sales_dat.h” header ,因为函数使用的结构 Sales_data 已在此处定义。但是在该文件中,我有非成员函数“读取”,它在结构 Sales_data 的构造函数之一中调用。因此,为了避免我在 sales_dat.h 中的结构定义之前转发声明的结构并声明读取函数。

我一直在尝试不同的方法,比如将 struct 的定义放在它自己的文件中,并将声明仅放在头文件中。但这给了我其他问题,编译器无法在我的非成员函数文件中使用它的对象。

我收到了那个错误,但我不明白为什么会收到上述错误。我在想这可能与 sales_prog.cpp 和 sales_function.cpp 中的“sales_dat.h” header 有关,但似乎我必须将它放在 sales_function.cpp 中以便非成员函数使用构造 Sales_data 对象。

这里到底发生了什么?销售函数.cpp

#include <iostream>
#include "sales_dat.h"
std::istream &read(std::istream &is, Sales_data &item)
{
double price = 0;
is >> item.bookName >> item.books_sold >> price;
item.revenue = price * item.books_sold;
return is;
}
std::ostream &print(std::ostream &os, Sales_data &item)
{
os << item.isbn() << " " << item.books_sold << " " << item.revenue;
return os;
}
Sales_data add(const Sales_data &lhs, const Sales_data &rhs)
{
Sales_data sum = lhs;
sum.combine(rhs);
return sum;
}

销售数据.h

#ifndef SALES_DAT_H
#define SALES_DAT_H
#include <iostream>
#include <string>
struct Sales_data;
std::istream &read(std::istream &, Sales_data &);
struct Sales_data {
std::string bookName;
std::string isbn() const { return bookName; }
Sales_data &combine(const Sales_data &);
unsigned books_available = 10;
unsigned books_sold = 0;
double revenue = 0;
unsigned total_sold = 0;
unsigned count = 1;
Sales_data() = default;
Sales_data(unsigned c) : count(c) {}
Sales_data(const std::string &s) : bookName(s) {}
Sales_data(const std::string &s, unsigned m, unsigned n, double p) : bookName(s), books_sold(m), books_available(n), revenue(p*m) {}
Sales_data(std::istream &inpst) { read(inpst, *this); }
};
std::ostream &print(std::ostream &, Sales_data &);
Sales_data add(const Sales_data &, const Sales_data &);
Sales_data &Sales_data::combine(const Sales_data &rs)
{
count += rs.count;
books_sold += rs.books_sold;
revenue += rs.revenue;
return *this;
}
#endif

sales_prog.cpp

#include <iostream>
#include <string>
#include "sales_dat.h"
int main()
{
std::cout << "Enter a transaction" << std::endl;
Sales_data total(std::cin);
if(std::cin) {
Sales_data trans;
while(read(std::cin,trans)) {
if(total.isbn() == trans.isbn()) {
total = add(total,trans);
}
else {
std::cout << "Number of " << total.isbn() << " transactions: " << total.count << std::endl;
std::cout << "Number of " << total.isbn() << " sold: " << total.books_sold << std::endl;
std::cout << "Revenue: " << total.revenue << std::endl;
total = trans;
}
}
if(total.books_sold != 0) {
std::cout << "Number of " << total.isbn() << " transactions: " << total.count << std::endl;
std::cout << "Number of " << total.isbn() << " sold: " << total.books_sold << std::endl;
std::cout << "Revenue: " << total.revenue << std::endl;
}
else
std::cout << "Entry: " << total.isbn() << " has zero sold" << std::endl;
}
else
std::cerr << "No transaction" << std::endl;
return 0;
}

最佳答案

Sales_data::combine 函数在头文件中定义,但您没有将其内联,因此包含该头文件的每个源文件都定义了该函数。

关于c++ - 链接器因重复符号而失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18549951/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com