- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我知道检查类型是否是采用TYPE 参数的类模板的实例化是微不足道的,如此处解释:How can I check if a type is an instantiation of a given class template?
但是...是否有可能有一个可变参数“is_instantiation_of__ntp<...>”(NTP 代表非类型参数)接受具有任意数量的异构 非类型参数?例如:
template<char*, bool, long, size_t, char>
struct many_hetero_nontype_params_example {};
char HELLO_WORLD[] = "hello world";
using ManyHeteroNontypeParamsEx = many_hetero_nontype_params_example<HELLO_WORLD, false, -16, 777, 'x'>;
并能够按如下方式使用它:
is_instantiation_of__ntp<char*, bool, long, size_t, char, many_hetero_nontype_params_example, ManyHeteroNontypeParamsEx>::value
我知道这对于非类型参数列表可以很容易地实现,这些参数列表是 1) “同类”(相同类型的值),或 2) 很少的参数(这样一个非可变参数的解决方案是实用的)。我什至写了一个测试用例来演示这些特殊情况(用 gcc 4.7.0 编译)以更好地理解我在说什么:
namespace test__is_instantiation_of__
{
// is_instantiation_of
template< template<typename...> class Template, typename T >
struct is_instantiation_of : std::false_type {};
template< template<typename...> class Template, typename... Args >
struct is_instantiation_of< Template, Template<Args...> > : std::true_type {};
// is_instantiation_of__homogeneous_nontype_params__
template< typename NTP, template<NTP...> class Template, typename T >
struct is_instantiation_of__homogeneous_nontype_params__ : std::false_type {};
template< typename NTP, template<NTP...> class Template, NTP... Args >
struct is_instantiation_of__homogeneous_nontype_params__< NTP, Template, Template<Args...> > : std::true_type {};
// is_instantiation_of__fixedcount_nontype_params__
template< typename NTP1, typename NTP2, template<NTP1, NTP2> class Template, typename T >
struct is_instantiation_of__fixedcount_nontype_params__ : std::false_type {};
template< typename NTP1, typename NTP2, template<NTP1, NTP2> class Template, NTP1 v1, NTP2 v2 >
struct is_instantiation_of__fixedcount_nontype_params__< NTP1, NTP2, Template, Template<v1, v2> > : std::true_type {};
// type_params_example
template<typename T1, typename T2, typename T3>
struct type_params_example {};
// homogeneous_nontype_params_example
template<bool B1, bool B2, bool B3, bool B4>
struct homogeneous_nontype_params_example {};
// fixedcount_nontype_params_example
template<long L, char C>
struct fixedcount_nontype_params_example {};
using /*.........*/ TypeParamsEx = /*..........*/ type_params_example<std::string, std::tuple<long, void*>, double>;
using HomogenousNontypeParamsEx = homogeneous_nontype_params_example<true, false, true, false>;
using FixedCountNontypeParamsEx = fixedcount_nontype_params_example<777, 'x'>;
void run()
{
using std::cout;
using std::endl;
if ( is_instantiation_of<type_params_example, TypeParamsEx>::value ) {
cout << "[TypeParamsEx] specializes [type_params_example]" << endl;
}
if ( is_instantiation_of<type_params_example, HomogenousNontypeParamsEx>::value ) {
cout << "[HomogenousNontypeParamsEx] specializes [type_params_example]" << endl;
}
if ( is_instantiation_of<type_params_example, FixedCountNontypeParamsEx>::value ) {
cout << "[FixedCountNontypeParamsEx] specializes [type_params_example]" << endl;
}
if ( is_instantiation_of__homogeneous_nontype_params__<bool, homogeneous_nontype_params_example, TypeParamsEx>::value ) {
cout << "[TypeParamsEx] specializes [homogeneous_nontype_params_example]" << endl;
}
if ( is_instantiation_of__homogeneous_nontype_params__<bool, homogeneous_nontype_params_example, HomogenousNontypeParamsEx>::value ) {
cout << "[HomogenousNontypeParamsEx] specializes [homogeneous_nontype_params_example]" << endl;
}
if ( is_instantiation_of__homogeneous_nontype_params__<bool, homogeneous_nontype_params_example, FixedCountNontypeParamsEx>::value ) {
cout << "[FixedCountNontypeParamsEx] specializes [homogeneous_nontype_params_example]" << endl;
}
if ( is_instantiation_of__fixedcount_nontype_params__<long, char, fixedcount_nontype_params_example, TypeParamsEx>::value ) {
cout << "[TypeParamsEx] specializes [fixedcount_nontype_params_example]" << endl;
}
if ( is_instantiation_of__fixedcount_nontype_params__<long, char, fixedcount_nontype_params_example, HomogenousNontypeParamsEx>::value ) {
cout << "[HomogenousNontypeParamsEx] specializes [fixedcount_nontype_params_example]" << endl;
}
if ( is_instantiation_of__fixedcount_nontype_params__<long, char, fixedcount_nontype_params_example, FixedCountNontypeParamsEx>::value ) {
cout << "[FixedCountNontypeParamsEx] specializes [fixedcount_nontype_params_example]" << endl;
}
}
}
正如预期的那样,您得到的输出是:
[TypeParamsEx] specializes [type_params_example]
[HomeogenousNonTypeParamsEx] specializes [homogeneous_nontype_params_example]
[FixedCountNonTypeParamsEx] specializes [fixedcount_nontype_params_example]
问题是这些模板都不适用于 many_hetero_nontype_params_example(上图)。即:一个单一的可变参数“is_instantiation_of__ntp”,它将接受具有任意数量的异构非类型参数的模板。
我认为如果主模板不需要在模板参数列表的末尾有参数包,那么这将很容易实现。或者是否可以使用包装器结构/嵌套结构方法。这是我的(失败的)尝试:
namespace test__is_instantiation_of__nontypes__
{
template<char*, bool, long, size_t, char>
struct many_hetero_nontype_params_example {};
char HELLO_WORLD[] = "hello world";
using ManyHeteroNontypeParamsEx = many_hetero_nontype_params_example<HELLO_WORLD, false, -16, 777, 'x'>;
/*
* is_instantiation_of__nontypes_v1__ (version 1)
* if uncommented, syntax error as expected ...
* error: parameter pack 'NTPs' must be at the end of the template parameter list
* error: parameter pack argument 'NTPs ...' must be at the end of the template argument list
*/
//template< typename... NTPs, template<NTPs...> class Template, typename T >
//struct is_instantiation_of__nontypes_v1__ : std::true_type {};
//template< typename... NTPs, template<NTPs...> class Template, NTPs... NonTypeArgs >
//struct is_instantiation_of__nontypes_v1__< NTPs..., Template, Template<NonTypeArgs...> > : std::true_type {};
/*
* is_instantiation_of__nontypes_v2__ (version 2)
* no syntax error (but see instantiation errors below)
*/
template<typename... NTPs>
struct is_instantiation_of__nontypes_v2__
{
template< template<NTPs...> class Template, typename T >
struct impl : std::false_type {};
template< template<NTPs...> class Template, NTPs... NonTypeArgs >
struct impl< Template, Template<NonTypeArgs...> > : std::true_type {};
};
void run()
{
/*
* uncommented since "v1" template has syntax error, but this is how it would be used ...
*/
//if ( is_instantiation_of__nontypes_v1__<char*, bool, long, size_t, char, many_hetero_nontype_params_example, ManyHeteroNontypeParamsEx>::value ) {
// std::cout << "yes" << std::endl;
//}
/*
* "v2" template has no syntax error, but the following attempt to use it results in these errors ...
*
* error: type/value mismatch at argument 1 in template parameter list for 'template<class ... NTPs> template<template<template<NTPs ...<anonymous> > class Template, class T> template<class ... NTPs> template<NTPs ...<anonymous> > class Template, class T> struct is_instantiation_of__nontypes_v2__<NTPs>::impl'
* error: expected a template of type 'template<class ... NTPs> template<NTPs ...<anonymous> > class Template', got 'template<char* <anonymous>, bool <anonymous>, long int <anonymous>, long unsigned int <anonymous>, char <anonymous> > struct many_hetero_nontype_params_example'
*/
//if ( is_instantiation_of__nontypes_v2__<char*, bool, long, size_t, char>::impl<many_hetero_nontype_params_example, ManyHeteroNontypeParamsEx>::value ) {
// std::cout << "yes" << std::endl;
//}
}
}
...
是否有可能对此使用可变参数解决方案?
提前致谢。
最佳答案
您可能遇到了编译器错误。我试图将其简化为一个更简单的示例:
#include <iostream>
template<bool, char> struct A { };
template<typename... Ts>
struct test
{
template<typename T>
struct impl : std::false_type {};
template<Ts... Args>
struct impl<A<Args...>> : std::true_type {};
};
int main()
{
using IA = A<false, 'x'>;
std::cout << ((test<bool, char>::impl<IA>::value) ? "Y" : "N");
}
GCC 4.7.2 编译这个,但是编译的程序 prints the wrong output (N
)。另一方面,Clang 3.2 做到了这一点,编译后的程序 prints the correct output (Y
)。
这是对上述程序稍作修改的版本,其中 test
类模板很像你的 is_instantiation_of__nontypes_v2__
类模板:
#include <iostream>
template<bool, char> struct A {};
template<typename... Ts>
struct test
{
template<template<Ts...> class TT, typename T>
struct impl : std::false_type {};
template<template<Ts...> class TT, Ts... Args>
struct impl<TT, TT<Args...>> : std::true_type {};
};
int main()
{
using IA = A<false, 'x'>;
std::cout << ((test<bool, char>::impl<A, IA>::value) ? "Y" : "N");
}
当 Clang 编译它并且编译后的程序打印出正确的输出 ( Y
) 时,GCC 发出以下编译错误:
expected a template of type
'template<class ... Ts> template<Ts ...<anonymous> > class TT'
, got'template<bool <anonymous>, char <anonymous> > struct A'
.
看起来 GCC 不承认第一个模板模板参数应该有一个由 Ts
的扩展给出的模板参数列表。 .因此,在我看来这是 GCC 的一个错误。
关于C++11:如何检查类型是否是 "heterogeneous"非类型参数的给定类模板的实例化?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15175829/
在 Windows 世界中,什么是正确的名称。具有导出函数的老式 C++ DLL?不是 COM DLL,也不是 .NET DLL。我们以前通过调用 LoadLibrary() 和 GetProcAdd
目前我正在使用javaEE7,我有一个场景如下。在我的 JSF Web 应用程序中,我有一个事件监听器(不是 JSF 事件),当事件调用时,它会执行某些操作,然后将这些信息更新到我的 Web 应用程序
这不是 AJAX 请求/响应回调问题... 我正在使用 Dojo 1.5 构建网格。我正在尝试 dojo.connect具有功能的扩展/收缩按钮。我的问题是 grid.startup()在创建实际 D
非 Webkit Opera 是 very specific在某些功能中,因此通常通过 JavaScript 检测到 the following way . 但是,Opera Next 几乎是 Goo
我已查看以下链接中给出的所有日志,但未能找到 IP 地址: https://developer.couchbase.com/documentation/server/3.x/admin/Misc/Tr
我有一个命令行程序,它根据一组源文件生成一个我想在我的 Android gradle 构建 (A) 中使用的 jar 文件。这个命令行程序只是将一个 jar 文件存储在磁盘上的一个目录中。 我如何创建
下面的 htaccess 命令将所有非 www 转移到 http www RewriteEngine On RewriteCond %{HTTP_HOST} !^www\. RewriteRule ^
我正在使用自定义链接器脚本将内核镜像分为两部分。第一个是普通代码和数据,第二个是初始化代码和不再需要时将被丢弃的数据。初始化部分也不像内核本身那样在地址空间之间共享,因此如果 fork() 仍然存在(
这个问题在这里已经有了答案: Several unary operators in C and C++ (3 个答案) What is the "-->" operator in C++? (29
假设我有一个类设置如下: class A { public: virtual void foo() { printf("default implementation\n"); } }; c
#include using namespace std; int main(int argc, char *argv[]) { int i=-5; while(~(i)) {
近期,百度搜索引擎变化无常,很多企业站、行业站、门户站、论坛等站点遭到了降权,特别是比比贴分类信息网直接遭到了拔毛,这对于广大站长来说是一种打击,也是各个企业、行业的打击。 至今,很多网站已经恢复
我现在正在使用 IBM TPM v1332 + IBM TSS v1470 并尝试将一些基本关键字/密码存储到 TPM 上的非 volatile 内存中。我找到了两种方法。一种是创建一个密封对象并使用
我的 PHP 脚本中有一个正则表达式,如下所示: /(\b$term|$term\b)(?!([^)/iu 这与 $term 中包含的单词匹配,只要前后有单词边界并且它不在 HTML 标记内即可。 但
我想显示用户名称地址(请参阅 www.ipchicken.com ),但我唯一能找到的是 IP 地址。我尝试了反向查找,但也没有用: IPAddress ip = IPAddress.Parse(th
只有 UI 线程能够显示到屏幕上,还是其他线程也可以这样做? 最佳答案 不,您只能直接从 UI 线程访问 UI,但您可以编码来自其他线程的结果,例如使用 Control.Invoke 或 contro
我正在使用现代 Excel 滚动条(不是旧的 ActiveX 类型,即开发人员 > 插入 > 表单控件 > 滚动条)并且想检测它的值何时更改。我找不到有关此类对象的更改事件的任何信息。您可以在单击时分
当我使用这段代码时 IE 6 确实正确使用了指定的样式表,但所有其他浏览器在应该使用基本上声明的样式表时会忽略这两种样式表,如果您不是 IE,请使用此样式表。 有什么想法吗? 最佳答案 n
我想指定 2 mssql 表之间的关系。 付款类别和付款。 paymentcategory.id 加入 payout.category 列。 在 payout.json 模型中 我指定为外键:id,
我正在尝试制作非 volatile UDF,但似乎不可能。因此,这是我非常简单的test-UDF: Option Explicit Dim i As Integer Sub Main() i = 0
我是一名优秀的程序员,十分优秀!