【发布时间】:2019-09-30 22:46:11
【问题描述】:
好的,我有这个代码:
// default implementation just uses a mutex to serialize access
template <typename T, typename=void>
struct kernport {
static const bool atomic = false;
// constructor
kernport(T value=T()) {
set(value);
}
// get/set value
T get() const { std::unique_lock<std::mutex> lock(lock_); return value_; }
void set(const T& value) { std::unique_lock<std::mutex> lock(lock_); value_ = value; }
private:
mutable std::mutex lock_;
T value_;
};
// specialization if std::atomic<T> exists
template <typename T>
struct kernport<T, void_type<decltype(std::atomic<T>())>> {
static const bool atomic = true;
// constructor
kernport(T value=T()) {
set(value);
}
// query port value
T get() const { return value_.load(std::memory_order_acquire); }
void set(const T& value) { value_.store(value, std::memory_order_release); }
private:
std::atomic<T> value_;
};
如果我尝试检查kernport<bool>::atomic,我会得到可怕的未定义引用。好的,所以我需要在类之外定义成员:
template <typename T> const bool kernport<T>::atomic;
不幸的是,这样做,我得到:
inc/skunk/dataflow/kernel.h:472:47:错误:模板定义 非模板 'const bool sk::kernport::atomic' 模板 const bool kernport::atomic;
对于我的生活,我可以找到正确的语法。这个怎么写?
【问题讨论】:
标签: c++ c++11 decltype partial-specialization class-template