- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 C++ 的新手,所以也许我做错了什么,但我无法弄清楚它是什么。
我对数据结构类的分配是实现以下头文件:
#ifndef __CS20A__Test__
#define __CS20A__Test__
#include <stdio.h>
namespace cs20a
{
class ThreeDPoint
{
public:
ThreeDPoint(int x, int y, int z);
double Distance() const;
friend bool operator ==(const ThreeDPoint &pt1, const ThreeDPoint &pt2);
friend bool operator !=(const ThreeDPoint &pt1, const ThreeDPoint &pt2);
friend ThreeDPoint operator +(const ThreeDPoint& pt1, const ThreeDPoint& pt2);
friend ThreeDPoint operator -(const ThreeDPoint& pt1, const ThreeDPoint& pt2);
//dot product
friend int operator *(const ThreeDPoint& pt1, const ThreeDPoint& pt2);
int getX() const;
int getY() const;
int getZ() const;
private:
int x;
int y;
int z;
};
}
#endif /* defined(__CS20A__Test__) */
这是我的实现: #include "ThreeDPoint.h" #包括 #包括
using namespace cs20a;
ThreeDPoint::ThreeDPoint(int x, int y, int z)
{
this->x = x;
this->y = y;
this->z = z;
}
double ThreeDPoint::Distance() const
{
return sqrt(pow(x, 2) + pow(y, 2) + pow(z, 2));
}
bool operator== (ThreeDPoint &pt1, ThreeDPoint &pt2)
{
return ((pt1.getX() == pt2.getX()) && (pt1.getY() == pt2.getY()) && (pt1.getZ() == pt2.getZ()));
}
bool operator !=(const ThreeDPoint &pt1, const ThreeDPoint &pt2)
{
return !(pt1.getX() == pt2.getX() && pt1.getY() == pt2.getY() && pt1.getZ() == pt2.getZ());
}
ThreeDPoint operator +(const ThreeDPoint& pt1, const ThreeDPoint& pt2)
{
return ThreeDPoint(pt1.getX() + pt2.getX(), pt1.getY() + pt2.getY(), pt1.getZ() + pt2.getZ());
}
ThreeDPoint operator -(const ThreeDPoint& pt1, const ThreeDPoint& pt2)
{
return ThreeDPoint(pt1.getX() - pt2.getX(), pt1.getY() - pt2.getY(), pt1.getZ() - pt2.getZ());
}
int operator *(const ThreeDPoint& pt1, const ThreeDPoint& pt2)
{
return pt1.getX() * pt2.getX() + pt1.getY() * pt2.getY() + pt1.getZ() * pt2.getZ();
}
int ThreeDPoint::getX() const {
return x;
}
int ThreeDPoint::getY() const {
return y;
}
int ThreeDPoint::getZ() const {
return z;
}
这两个文件本身编译得很好,但是当我添加一个驱动程序时
#include <iostream>
#include "ThreeDPoint.h"
int main(int argc, const char * argv[]) {
cs20a::ThreeDPoint pt1(1,2,3);
cs20a::ThreeDPoint pt2(1,2,3);
// insert code here...
std::cout << (pt1 == pt2);
return 0;
}
或任何具有 ThreeDPoint == ThreeDPoint 或 ThreeDPoint + ThreeDPoint 的驱动程序,当我尝试构建它时,出现此错误:
Ld /Users/jaredjensen/Library/Developer/Xcode/DerivedData/CS20A-fztpdusrphrftebtzmkhjpjcduym/Build/Products/Debug/CS20A normal x86_64
cd "/Users/jaredjensen/Google Drive/XCode/CS20A"
export MACOSX_DEPLOYMENT_TARGET=10.9 /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/clang++ -arch x86_64 -isysroot /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.10.sdk -L/Users/jaredjensen/Library/Developer/Xcode/DerivedData/CS20A-fztpdusrphrftebtzmkhjpjcduym/Build/Products/Debug -F/Users/jaredjensen/Library/Developer/Xcode/DerivedData/CS20A-fztpdusrphrftebtzmkhjpjcduym/Build/Products/Debug -filelist /Users/jaredjensen/Library/Developer/Xcode/DerivedData/CS20A-fztpdusrphrftebtzmkhjpjcduym/Build/Intermediates/CS20A.build/Debug/CS20A.build/Objects-normal/x86_64/CS20A.LinkFileList -mmacosx-version-min=10.9 -stdlib=libc++ -Xlinker -dependency_info -Xlinker /Users/jaredjensen/Library/Developer/Xcode/DerivedData/CS20A-fztpdusrphrftebtzmkhjpjcduym/Build/Intermediates/CS20A.build/Debug/CS20A.build/Objects-normal/x86_64/CS20A_dependency_info.dat -o /Users/jaredjensen/Library/Developer/Xcode/DerivedData/CS20A-fztpdusrphrftebtzmkhjpjcduym/Build/Products/Debug/CS20A
Undefined symbols for architecture x86_64:
"cs20a::operator==(cs20a::ThreeDPoint const&, cs20a::ThreeDPoint const&)", referenced from:
_main in main.o
ld: symbol(s) not found for architecture x86_64
clang: error: linker command failed with exit code 1 (use -v to see invocation)
我已经尝试了所有方法,但无法修复此错误。只有当我让运算符(operator)成为 friend 功能时才会发生这种情况。如果我让他们成为成员,并删除其中一个参数,它就可以正常工作。我做错了什么吗?
最佳答案
你忘记了 cpp
文件中的 ThreeDPoint::before 运算符,并使用二元运算符而不是 friend
/*.cpp add ThreaDproint before operator*/
bool ThreeDPoint::operator== (ThreeDPoint const & pt2)
{
return ((this->x == pt2.getX()) && (this->y == pt2.getY()) && (this->z == pt2.getZ()));
}
bool ThreeDPoint::operator !=(const ThreeDPoint &pt2)
{
return !(this->x == pt2.getX() && this->y == pt2.getY() && this->z == pt2.getZ());
/* here you can do this
return !(this->operator==(pt2)); */
}
/* .h change friend for binary operator*/
bool operator ==(const ThreeDPoint &pt2);
bool operator !=(const ThreeDPoint &pt2);
编辑:强制使用好友关键字
/* add cs20a:: before operator== */
bool cs20a::operator==(const ThreeDPoint &pt1, const ThreeDPoint &pt2)
{
return (pt1.x == pt2.x && pt1.y == pt2.y && pt1.z == pt2.z);
}
祝你好运:)
关于c++ - Apple Mach-O Linker (Id) 在 C++ 中创建运算符友元函数时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31091597/
我的makefile的一部分看起来像这样...... ifdef vis flg += -framework GLUT -framework OpenGL -Dvis obj += camfun.o
我正在尝试将 MPI 与 D 编程语言结合使用。 D 完全支持 C ABI,可以链接和调用任何 C 代码。我已经完成了显而易见的工作并将 MPI header 翻译为 D。然后我翻译了 a test
我研究了 makefile 项目。我正在使用 gnu gcc 并作为链接器,我使用带有以下参数的 gcc: linkerCmdLine=$(exe) -Wl,--start-group -nostdl
我尝试使用 FMDB 数据库,但出现错误: Undefined symbols for architecture i386: "_OBJC_CLASS_$_FMDatabase", referen
我想知道“本地链接器符号”和“本地程序变量”之间的区别? 我正在读一本书,里面有这样的: alt text http://img682.imageshack.us/img682/9816/symbol
假设我正在使用 clang 构建和链接我的应用程序 clang -I/usr/local/include -c -o app.o main.c clang -L/usr/local/lib -o ap
我正在从程序员的角度阅读计算机系统,关于链接的章节。它解释了如何使用程序 ld 在 linux x86-64 中进行链接。作者声称,为了从可重定位的目标文件构建可执行文件,链接器做了两件事:符号解析和
所以,这是我发现自己想到的任务。假装一下,我有大量的内容。我想查看哪些网站链接到我的内容。我知道我可以研究 TrackBack 或 PingBack,但是那些不使用能够处理这些问题的工具的人呢? 似乎
我认为 动态加载意味着在加载或运行时将库(或任何其他二进制文件)加载到内存中。所以在下面的程序中,当 dlopen() 调用动态加载器时,它会出现,如果库尚未加载,它会将库加载到内存中。 动态链接是指
我想澄清我对共享库的困惑。当我在网上搜索时,我在对静态链接的解释中发现,由于库包含在可执行文件本身中,因此它会导致更大的可执行文件,从而增加程序的内存占用。 而在动态库/共享库的情况下,库是在运行时链
我正在开发一个嵌入式系统(Stellaris Launchpad)并编写一个简单的操作系统(作为一个爱好项目)。使用的工具链是 gcc-none-eabi。 我的下一步是习惯 MPU 以允许内核阻止用
我正在与 JNI 合作。我有一个包装库 (wrapper.so),它使用两个共享库:one.so 和 two.so 一切正常。所有 *.so 都在 lib 文件夹中,在程序文件夹内。 问题是,如果我将
使用通过“node-gyp”传递的链接器命令行选项,我指定了我希望程序链接的库路径和库名称。但是生成的可执行文件没有引用我指定的文件,它在 /usr/lib 中引用了一个不同的名称。 . 我正在使用
我正在为 AWS lambda 开发 native 节点模块。此节点模块需要 json-c 根据 AWS lambda guidelines节点模块不应具有动态依赖关系。所以尝试链接json-c库的静
我想配置一个自动工具化的项目来调用一个非标准的 链接器( gold linker ), 使用 Linux Mint 16/Ubuntu 13.10 的库存自动工具 我相信我会通过以下方式实现这一目标:
要将可执行文件与位于标准位置的库链接,可以在 CmakeLists.txt 文件中执行以下操作: create_executable(generate_mesh generate_mesh.cpp)
链接描述脚本是否可以访问makefile/shell变量并根据所述变量做出决定? 例如,假设我想在不使用其他链接程序脚本的情况下更改下面RAM区域的开始,是否可以使用make变量来执行此操作? MEM
第三方为我提供了一个静态lib(.a)以便与solaris站链接。 我尝试使用sunpro进行编译,但在链接步骤失败。 我想问题出在我使用的编译器(而不是gcc?)或它的版本(由于编译器提供的std
当我们编译代码时,将生成一个目标文件。在链接过程中,从该目标文件生成一个可执行文件。 为什么我们需要一个目标文件?目标文件有什么用?不可能直接生成可执行文件吗?毕竟,我们使用可执行文件来运行该程序。
我知道头文件包含函数和变量的声明,它们在编译期间帮助判断输入的参数是否有效。 所有的库函数都是默认链接的吗? //#include //#include int main() { printf
我是一名优秀的程序员,十分优秀!