标签:c c11 templates unique-ptr
当容器(例如:std :: vector)传递给函数模板时,是否有可能从容器中抽象出对象的指针类型?
我有以下两种方法:
template <typename T, typename allocT, template <typename, typename> class containerT>
static void parse(containerT<T *, allocT> &entries, const rapidjson::Value &jsonDocument)
{
for (rapidjson::SizeType entryIt = 0; entryIt < jsonDocument.Size(); ++entryIt)
{
entries.push_back(new T());
entries[entryIt]->parse(jsonDocument[entryIt]);
}
}
和
template <typename T, typename allocT, template <typename, typename> class containerT>
static void parse(containerT<std::unique_ptr<T>, allocT> &entries, const rapidjson::Value &jsonDocument)
{
for (rapidjson::SizeType entryIt = 0; entryIt < jsonDocument.Size(); ++entryIt)
{
entries.push_back(std::move(std::unique_ptr<T>(new T())));
entries[entryIt]->parse(jsonDocument[entryIt]);
}
}
我们暂时忽略std :: move调用.如您所见,除了推回新对象外,这两种方法几乎都做同样的事情.如果我只有一种方法会更好.
怎么能实现这一目标? decltype有用吗?我找不到办法做到这一点.
需要这个的基本原理是旧代码使用原始指针和带有智能指针的新代码调用方法,因此无法快速切换到新模式.
解决方法:
template <typename P, typename allocT, template <typename, typename> class containerT>
static void parse(containerT<P, allocT> &entries, const rapidjson::Value &jsonDocument)
{
for (rapidjson::SizeType entryIt = 0; entryIt < jsonDocument.Size(); ++entryIt)
{
entries.emplace_back(new typename std::pointer_traits<P>::element_type());
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^
entries[entryIt]->parse(jsonDocument[entryIt]);
}
}
标签:c,c11,templates,unique-ptr 来源: https://codeday.me/bug/20190829/1763163.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。