我正在使用C ++库( strf),该某个位置具有以下代码:
namespace strf {
template <typename ForwardIt>
inline auto range(ForwardIt begin, ForwardIt end) { /* ... */ }
template <typename Range, typename CharT>
inline auto range(const Range& range, const CharT* sep) { /* ... */ }
}
现在,我想使用 strf::range<const char*>(some_char_ptr, some_char_ptr + some_length)
在我的代码中。但是,如果这样做,我将收到以下错误(使用CUDA 10.1的NVCC):
error: more than one instance of overloaded function "strf::range" matches the argument list:
function template "auto strf::range(ForwardIt, ForwardIt)"
function template "auto strf::range(const Range &, const CharT *)"
argument types are: (util::constexpr_string::const_iterator, util::constexpr_string::const_iterator)
的 库的代码也许可以被改变,以避免这一点(例如,使用:
inline auto range(const typename std::enable_if<not std::is_pointer<typename std::remove_cv<Range>::type>::value, Range &>::type range, const CharT* sep)
确保Range
不是指针);但我现在无法进行更改。相反,我想以某种方式向编译器指示,我实际上的意思是只具有一个模板参数,而不指定一个并推导出另一个。
我可以那样做吗?
希望能得到C ++ 11和C ++ 14的答案;涉及推导指南的C ++ 17答案不太相关,但如果有,请张贴(针对将来的NVCC版本...)
更新: strf库本身已经更新,可以避免这种情况,但是问题仍然存在。
char*
但不是一个不是解决方案吗?