試圖更好地理解本周提示 #42:通過使用標準模板庫復制示例,優先使用工廠函式而不是初始化方法。OP 提供了示例代碼:
// foo.h
class Foo {
public:
// Factory method: creates and returns a Foo.
// May return null on failure.
static std::unique_ptr<Foo> Create();
// Foo is not copyable.
Foo(const Foo&) = delete;
Foo& operator=(const Foo&) = delete;
private:
// Clients can't invoke the constructor directly.
Foo();
};
// foo.c
std::unique_ptr<Foo> Foo::Create() {
// Note that since Foo's constructor is private, we have to use new.
return absl::WrapUnique(new Foo());
}
在嘗試復制示例時,我在本foo.c節中使用了不同的方法:
std::unique_ptr<Foo> Foo::Create() {
// Attempt to create using std::unique_ptr instead of absl::WrapUnique
return std::unique_ptr<Foo>(new Foo());
}
使用以下命令編譯會導致聯結器命令失敗
$ clang -g -Wall -std=c 11 -fsanitize=address foo.cc -o Foo
Undefined symbols for architecture arm64:
"Foo::Foo()", referenced from:
Foo::Create() in robots-cda3fd.o
ld: symbol(s) not found for architecture arm64
clang: error: linker command failed with exit code 1 (use -v to see invocation)
關于我在這里缺少什么的想法?謝謝!
uj5u.com熱心網友回復:
你仍然需要定義 Foo::Foo()
- 在標題中你可以做
Foo() = default,甚至在私人部分 - 在 cpp 中,您可以執行
Foo::Foo() = default或Foo::Foo() {}
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/368073.html
