在这种情况下,我需要通过using
(或任何其他方法)使用类型别名:
template <class T>
typename std::enable_if< /*HERE*/>::value
f (...) {};
在我写HERE
的地方,结构内部定义了很长且不止一种类型,typename <very long templated struct dependent on T>::type
我不想写,而是想写一个快捷方式。
我在更多情况下遇到了这种情况,例如模板特化和后缀返回类型语法。那么在第一行和结构/类或函数using
之间的位置是否有任何使用方式(没有双关语)?template <...>
我尝试过使用,
(逗号)类似(using X = ... , /*actually using X*/)
但没有成功的东西。
有效的是全球范围的using
template <class Iterator>
using DT = typename DereferenceType<Iterator>::type&;
但我不想要全局范围,我希望范围仅适用于我使用它的模板。我不想写DT<Iterator>
,只是DT
。
不用说宏或任何预处理器指令都是不可能的。
现实生活中的例子:
template <class Iterator, class GetCompValue, class SortOrder = Ascending>
typename std::enable_if<
IsDereferenceable<Iterator>::value &&
IsCallableLike<GetCompValue,
typename DereferenceType<Iterator>::type&(
typename DereferenceType<Iterator>::type&)>::value &&
IsSortOrder<SortOrder>::value, void>::type
RadixSortLSDByteOffsetIter(Iterator first, Iterator last,
GetCompValue get_comp_value, SortOrder = kAscending) {
在这里,我想要一个快捷方式,typename DereferenceType<Iterator>::type&
例如:
template <class Iterator, class GetCompValue, class SortOrder = Ascending>
// using DT = typename DereferenceType<Iterator>::type&;
typename std::enable_if<
IsDereferenceable<Iterator>::value &&
IsCallableLike<GetCompValue, DT(DT)>::value &&
IsSortOrder<SortOrder>::value, void>::type
RadixSortLSDByteOffsetIter(Iterator first, Iterator last,
GetCompValue get_comp_value, SortOrder = kAscending) {
谢谢你。