草庐IT

enable_if_c

全部标签

c++ - boost::enable_if_c 似乎不起作用

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Howtouseenable_iftoenablememberfunctionsbasedontemplateparameterofclass我有一个类模板:templateclassVector我想为特定的N启用构造函数,所以我这样做:Vector(typenameboost::enable_if_c::typeconst&e0,Tconst&e1){data[0]=e0;data[1]=e1;}但是编译器(MSVC2010SP1)给我一个错误,而不是应用SFINAE。错误是:errorC2039:'typ

c++ - unordered_set::remove_if(): C3892: 无法分配给常量变量

我有这样的代码:unordered_setoutput;...autorequiredType=variables.at(arg.value);autoend=remove_if(output.begin(),output.end(),[&](AttrValuex){return!matchingOutputType(requiredType,ast->getNodeType(ast->getNodeKeyAttribute(x)));});//queryevaluator_getcandidatelist.cpp(179)output.erase(end);错误在代码的第4行。所以我

c++ - 如何正确使用enable_if?

我需要学习如何使用enable_if。为此,我需要使用enable_if重新实现距离函数。我试过这个:#include#include#include#include#includetemplatetypenamestd::enable_if::value,std::iterator_traits::difference_type>::typemy_distance(Inbegin,Inend,std::input_iterator_tagdummy){typenamestd::iterator_traits::difference_typen=0;while(begin!=end){

C++11 Dynamic Cast If Else Chain -> 开关

考虑以下几点:structB{};templatestructD:B{Tt;}voidg(inti){...}voidg(strings){...}voidg(charc){...}voidf(B*b){if(dynamic_cast*>(b)){g(dynamic_cast*>(b)->t);}elseif(dynamic_cast*>(b)){g(dynamic_cast*>(b)->t);}elseif(dynamic_cast*>(b)){g(dynamic_cast*>(c)->t)}elsethrowerror;};这里只有三种可能的T类型——int、string、char

c++ - 无限递归 `enable_if`

在尝试为另一种类型T编写wrapper类型时,我遇到了一个相当令人讨厌的问题:我想定义一些二元运算符(例如+)将wrapper上的任何操作转发给底层类型,但我需要这些运算符接受任何涉及wrapper的潜在组合:wrapper()+wrapper()wrapper()+T()T()+wrapper()天真的方法涉及直接编写所有潜在的重载。但我不喜欢编写重复的代码并且想要更多的挑战,所以我选择使用一个非常通用的模板来实现它并使用enable_if限制潜在的类型。我的尝试显示在问题的底部(抱歉,这是我能想到的最小值)。问题是它会遇到无限递归错误:为了评估test()+test(),编译会查看

c++ - Visual Studio 2010 调试 "if (var == NULL)"未触发

已解决-构造函数问题MatthewFlaschen和MichaelBurr指出Node(int)的重载构造函数调用Node()不起作用的问题because...谢谢大家!我已经构建了一个程序(我正在调试它)并且遇到了一个奇怪的问题......一个`if`语句没有在它应该被触发的时候被触发......这是一个学校项目,我们必须构建一个具有至少一个“优化”功能的AVL树。我确信并测试过`rdown`和`ldown`起作用(作为平衡因素)——树不是完全平衡的。相反,它基于分支的高度(即-`balance()`应该只返回(1,0,-1)否则它是不平衡的。我希望这些信息足以解决这个奇怪的问题..

c++ - enable_if'ed 模板化模板构造函数的类型签名?

我通常先声明我的类和模板,然后再定义它们的方法(当然是在同一个头文件中)。我只是觉得这样更容易阅读。好吧,我遇到过这样一种情况,我无法找出在类外定义中使用的有效类型签名。这是我正在做的一个简化示例,它说明了问题:templatestructFoo{Foo(Ta,Tb);template>>Foo(Iteratorfirst,Iteratorlast);};templateFoo::Foo(Ta,Tb){...}templatetemplateFoo::Foo(Uf,Ul){...}我在WHAT_GOES_HERE槽中尝试了很多方法来尝试获得匹配的签名,但我一直失败。我需要enable_

c++ - 优化头痛 - 从查找表中删除 if's

我正在尝试优化以下代码,这是我的应用程序中的瓶颈。它的作用:它采用double值value1和value2并尝试找到包含校正因子的最大值。如果两个值之间的差异大于5.0(LUT按因子10缩放),我可以取这两个值的最大值。如果差异小于5.0,我可以使用LUT中的校正因子。有没有人知道什么是这段代码的更好风格?我不知道我在哪里浪费了时间-是大量的ifs还是乘以10?doublevalue1,value2;//LookupTablescaledby10for(ln(1+exp(-abs(x)))),whichisalmost0forx>5andsymmetricalaround0.LUT[0

本地运行没错,打包后在服务器上报错We’re sorry but XXX doesn’t work properly without JavaScript enabled

本地运行没错,打包后在服务器上报错We’resorrybutXXXdoesn’tworkproperlywithoutJavaScriptenabled需要访问两个服务器,使用了网络代理,在本地运行是正常的,打包后报错,再尝试多种解决办法没有生效后,又刷到了‘风弥漫了夏天’这个博主的文章,试了改nginx配置,完美解决具体方法nginx配置文件增加配置如下因为我原本有一个后端服务器,所以这个是新增的,所以,这个api及服务器ip,端口改为新增的服务器信息。//ip是后端项目发布的服务器的ip,port是后端允许访问的端口,即项目端口//api是前端使用的请求后端的时候的基础urilocatio

c++ - constexpr if with initializer 由标准保证吗? 'constexpr(constexpr auto x = f(); x) { }'

我找不到任何关于新C++17if初始化语法的信息和“constexprif”在:http://open-std.org/JTC1/SC22/WG21/docs/papers/2016/p0128r1.html不过,Clang-HEAD支持该语法...constexprautof(){returntrue;}intmain(){ifconstexpr(constexprautox=f();x){}}在线代码在这里->http://melpon.org/wandbox/permlink/dj3a9ChvjhlNc8nr是constexprif带有标准保证的初始值设定项,如constexpr