- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我将一个类的成员函数的签名和实际指针作为模板类的模板参数传递。有没有办法为运算符重载对此类进行不同的特化?我试图查看 type_traits
并从 std::is_copy_assignable
获得提示,但似乎 g++ 使用内置函数(__has_trivial_copy
示例)。
最佳答案
嗯,我研究过这个问题。
我认为可以得到结果,但它相当复杂,因为 A 类想要知道它自己的模板参数之一是否是 B 类的运算符,它必须首先检查 B::operator 是否存在,然后检查它是否等于模板参数。这迅速增加了任务的难度。
此外,我在测试时发现,g++对高级模板使用的支持仍然很差。例如这段代码做第2步,即假设某个成员函数存在,检查模板参数是否等于同一个成员函数:
#include <iostream>
using namespace std;
struct Hello{
int helloworld(){
return 0;
}
int goodbyeworld(){
return 0;
}
};
template<typename T1, T1, typename T2, T2> struct is_same_method{
static constexpr bool value=false;
};
template<typename Return, typename Class, typename... Args, Return(Class::*member)(Args...)>
struct is_same_method<Return(Class::*)(Args...), member, Return(Class::*)(Args...), member>{
static constexpr bool value=true;
};
#define method_test(a, b) is_same_method<decltype(a), a, decltype(b), b>::value
template<typename T, T> struct what_am_I_passed;
template<typename Return, typename Class, typename... Args, Return(Class::*member)(Args...)>
struct what_am_I_passed<Return(Class::*)(Args...), member>{
static void so_what(){
/*
* error: ‘decltype (& Class:: helloworld)’ is not a valid type for a template constant parameter.
*/
cout<<"you passed me "<<(method_test(member, &Class::helloworld)?"helloworld":"something else")<<endl;
}
};
int main(){
what_am_I_passed<decltype(&Hello::helloworld), &Hello::helloworld>::so_what();
}
现在,此代码在 g++ 4.4、4.5 中失败,在 4.6.1 中崩溃,并从 4.6.2 开始工作。
在所有这些麻烦之后,我决定在运行时移植一些逻辑。这就是我的结局。
#include <iostream>
#include <type_traits>
using namespace std;
template<typename mem_type, mem_type mem> struct operator_type{
enum types{
//complete me...
NONE=0, ADD, SUB, MUL, DIV, MOD, POW, UNM, EQ, NEQ, LT, LE, GT, GE, SUBSCRIPT, CALL
};
static types what(){ return NONE; }
};
typedef operator_type<int, 0>::types op_types;
template<typename Return, typename Class, typename... Args, Return(Class::*mem)(Args...)>
class operator_type<Return(Class::*)(Args...), mem>{
#define isOp(name, symbol, args)\
template<typename Class_,int=0> static bool is##name(float&&){ return false; }\
template<typename Class_, Return(Class_::*innermem)(Args...)=&Class_::operator symbol>\
static bool is##name(int&&){ return innermem==mem && (args<0 || sizeof...(Args)==args); }
#define testOp(name) if(is##name<Class>(0)) return op_types::name
//complete me...
isOp(ADD, +, 1)
isOp(SUB, -, 1)
isOp(MUL, *, 1)
isOp(DIV, /, 1)
isOp(MOD, %, 1)
isOp(POW, ^, 1)
isOp(UNM, -, 0)
isOp(EQ, ==, 1)
isOp(NEQ, !=, 1)
isOp(LT, <, 1)
isOp(LE, <=, 1)
isOp(GT, >, 1)
isOp(GE, >=, 1)
isOp(SUBSCRIPT, [], 1)
isOp(CALL, (), -1)
public:
static op_types what(){
//complete me...
testOp(ADD);
testOp(SUB);
testOp(MUL);
testOp(DIV);
testOp(MOD);
testOp(POW);
testOp(UNM);
testOp(EQ);
testOp(NEQ);
testOp(LT);
testOp(LE);
testOp(GT);
testOp(GE);
testOp(SUBSCRIPT);
testOp(CALL);
return op_types::NONE;
}
};
template<typename T, T> struct wants_to_know_operators;
template<typename Return, typename Class, typename... Args, Return(Class::*mem)(Args...)>
struct wants_to_know_operators<Return(Class::*)(Args...), mem>{
typedef operator_type<decltype(mem), mem> my_operator_type;
static void stuff(){
switch(my_operator_type::what()){
case op_types::NONE: cout<<"this is not an operator"<<endl; break;
case op_types::CALL: cout<<"this is operator()"<<endl; break;
case op_types::SUBSCRIPT: cout<<"this is operator[]"<<endl; break;
case op_types::SUB: cout<<"this is operator-"<<endl; break;
case op_types::UNM: cout<<"this is operator- (unary)"<<endl; break;
//complete me...
default: cout<<"something else..."<<endl; break;
}
}
};
struct Test{
void operator()(){
}
Test& operator-(){
return *this;
}
Test& operator-(int){
return *this;
}
int operator[](int){
return 0;
}
int operator[](iostream){
return 0;
}
int operator==(int){
return 0;
}
void f(){}
};
int main(){
wants_to_know_operators<decltype(&Test::f), &Test::f>::stuff();
wants_to_know_operators<int(Test::*)(int), &Test::operator[]>::stuff();
wants_to_know_operators<int(Test::*)(iostream), &Test::operator[]>::stuff();
wants_to_know_operators<decltype(&Test::operator()), &Test::operator()>::stuff();
wants_to_know_operators<decltype(&Test::operator==), &Test::operator==>::stuff();
wants_to_know_operators<Test&(Test::*)(), &Test::operator- >::stuff();
wants_to_know_operators<Test&(Test::*)(int), &Test::operator- >::stuff();
}
语法有点麻烦,但它是我能用模板处理的最好的语法。请注意,它可以区分同一运算符的不同重载。对于我的目标,这就足够了,甚至可能更可取,因为整个事情都是关于将 C++ 函数导出到 Lua,当然你不能在编译时将东西压入 Lua 堆栈。
关于c++ - 我可以在编译时检查成员函数是否是运算符吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10209008/
我需要根据需要动态设置文本区域,但它不想正常工作。 JQuery 会自行检查,但无法检查是否已检查。但是当您在第二个单选框内单击时,始终需要文本区域。我尝试了很多次让它工作,但它仍然有问题。我添加了“
我需要在 Django 中进行 API 调用(某种形式),作为我们所需的自定义身份验证系统的一部分。用户名和密码通过 SSL 发送到特定 URL(对这些参数使用 GET),响应应该是 HTTP 200
我将在我的可移植 C 代码中使用 #warning 来生成编译时警告。但并非所有平台都支持 #warning。有什么方法可以找到该平台是否支持 #warning。 #ifdef warning
我编写了一个函数来检查某个数字是否存在于某个区间内。停止搜索的最佳方法是什么?这个: for (i = a; i <= b; i++) { fi = f(i); if (fi == c) {
我想知道在 c 中是否有一种方法可以检查,例如在 for 函数中,如果变量等于或不等于某些字符,而不必每次都重复进行相等性检查。如果我没记错的话,以这种方式检查相等性是不正确的: if (a == (
我有如下日志功能 void log_error(char * file_name, int line_num, int err_code) { printf("%s:%d:%s\n", fil
使用 ssh-keygen 生成的 key 对在 macOS 上可以有不同的格式。 macOS 可读的标准 PEM ASN.1 对象 SecKey API 带有文本标题的 PEM OpenSSH ke
我正在尝试编写一个 excel if 语句。我不熟悉使用 Excel 具有的所有额外功能。我正在使用一个名为 importXML() 的函数.我正在尝试检查我正在使用的函数是否生成“#VALUE!”错
有没有办法检查是否没有 AIO 写入给定文件?我在我的 Unix 类(class)上制作了一个项目,该项目将是一个上下文无关(基于 UDP)的国际象棋服务器,并且所有数据都必须存储在文件中。应用程序将
我有一个如下所示的函数: public Status execute() { Status status = doSomething(); if (status != Stat
我正在使用 Composer,我不希望 PhpStorm 在 vendor 文件夹上运行任何错误检查或检查,因为它对 vendor/中的某些代码显示误报composer/autoload_static
Chapel 的一个很好的特性是它区分了数组的域和它的分布。检查两个数组是否具有相同的域和分布(通常想要的)的最佳方法是什么? 我能看到的最好的方法是检查 D1==D2和 D1.dist==D2.di
在我的 JavaScript 函数中,我为所有输入、文本区域和选择字段提供实际值作为 initial_value: $('input, textarea, select').each(function
我正在编写一个分解为几个简单函数的 PHP 类。在构造函数中,它调用另一个名为 processFile 的函数。该函数调用 5 个私有(private)函数并进行检查。如果检查失败,它会将消息分配给
这个问题已经有答案了: How to detect if user it trying to open a link in a new tab? (2 个回答) 已关闭 7 年前。 我认为 JavaS
我正在浏览我们的代码库并看到很多这样的测试: declare @row_id int = ... declare @row_attribute string select @row_attribu
我正在声明一个用作比较的函数。我的问题是: 为什么条件充当语句? 为什么第 4 行可以工作,而第 5 行却不行? 我知道这段代码不切实际且未使用,但为什么编译器允许这种语法? 谷歌没有找到答案。但话又
到目前为止,我有一个带有空文本字段的 PHP Kontaktform,并使用以下命令检查了所需的字段: $name = check_input($_POST['name'], "请输入姓名。"); 现
目前,我能想到的合理检查的唯一方法没有臃肿的逻辑: if ( $value > 0 ) { // Okay } else { // Not Okay } 有没有更好的办法? 最佳答案
我正在尝试运行一个脚本,如果 i 存在(意味着存在 i 值,任何值)或其他部分,我希望运行其中的一部分如果i没有值就运行,有人可以启发我吗? 我说的是 for 循环,比如 for (var i=0;
我是一名优秀的程序员,十分优秀!