草庐IT

Re-enable

全部标签

c++ - 标准授权 enable_shared_from_this 是否公开继承?为什么?

从enable_shared_from_this继承是很常见的,只是为了能够从成员函数返回shared_ptr作为主要目的,而不是暴露enable_shared_from_this派生类中的API。由于要使用enable_shared_from_this必须通过公共(public)继承来实现(标准是否强制要求这样做?理由是什么?),这是无法实现的并且enable_shared_from_thisAPI被强制进入派生类公共(public)API。私下继承enable_shared_from_this并使shared_ptr成为友元类可以在clang上与libc++结合使用,但不适用于st

c++ - 混合 decltype 和 enable_if

似乎将decltype与SFINAEenable_if一起使用并不简单。我尝试以三种不同的方式使用enable_if编写go。所有这些都因编译器错误而失败(GCC的字面意思是:“错误:'thing'不是'foo'的成员”和实例化上下文)。#includestructfoo{enum{has_thing=false};};structbar{enum{has_thing=true};staticintthing(){return0;}};templatestructTest{/*autogo(typenamestd::enable_if::type=0)->decltype(T::thi

C++智能指针enable_shared_from_this

enable_shared_from_this介绍enable_shared_from_this其实是智能指针中的内容,它的作用就是用于在类的内部,返回一个this的智能指针。对于enable_shared_from_this,初学者可能不明白它的使用场景和使用的必要性,可能有得童鞋们会问既然有了this这个指向自己的指针,为什么还需要enable_shared_from_this这个东西呢,直接用this代替不就好了吗?我们来看看以下代码例子,如果先不运行,你能看出什么问题吗?#includeclassPerson{public:Person()=default;~Person(){};st

c++ - 为什么这个enable_if函数模板不能专用于VS2017?

以下使用VS2015编译,但在VS2017中失败并出现以下错误。代码是否在做一些非标准的事情,已在VS2017中修复,或者VS2017应该编译它?#include"stdafx.h"#includetemplateconstexprautoToUnderlying(Ee){returnstatic_cast>(e);}templateboolconstexprIsFlags(T){returnfalse;}templatestd::enable_if_t>operator|(Elhs,Erhs){returnToUnderlying(lhs)|ToUnderlying(rhs);}en

Python常用模块 之 re模块

re模块每篇前言:0.正则表达式所面向的问题1.正则表达式RE(1)基础:1.代码演示:3.常用匹配规则(元字符):(1)什么是元字符?(2)常用元字符有哪些?4.正则表达式的转义:5.贪婪模式和非贪婪模式:(2)函数:(1)re.findall(pattern,string,flags=0)(2)re.match(pattern,string,flags=0)第一部分:第二部分:

c++ - 我可以将 enable_if 与 typedef 一起使用吗?

我想定义一个类型取决于某些条件的变量。我想要这样的东西:typedeftypenameenable_if::typeType;typedeftypenameenable_if::typeType;但是编译器说我重新定义了类型。我该怎么做? 最佳答案 CanIuseenable_iftogetherwithtypedef?不,你不能。std::enable_if如果条件为假,则保留类型未定义。只有条件为真,成员type才被定义;templatestructenable_if;IfBistrue,std::enable_ifhasapu

c++ - boost::enable_if 不在函数签名中

这只是一个关于样式的问题:我不喜欢C++的模板元编程方式,它要求您使用返回类型或为SFINAE的技巧添加额外的虚拟参数。所以,我想到的是将SFINAE放在模板参数定义本身中,如下所示:#include#include#includeusingnamespacestd;template>::type>voidasd(){cout>::type>voidasd(){cout();asd();}这个例子让g++提示:../src/afg.cpp:10:97:error:redefinitionof‘templatevoidasd()’SFINAE本身可以工作,因为如果我删除例如带有disab

c++ - SFINAE enable_if 显式构造函数

我正在尝试通过enable_if在显式和隐式转换构造函数之间切换。我的代码目前看起来像#include#includeenumclassenabled{};templateusingenable_if_t=typenamestd::enable_if::type;templateusingdisable_if_t=typenamestd::enable_if::type;templatestructSStruct{staticconstexprstd::intmax_ta=A;};templatestructSCheckEnable:std::integral_constant{};t

深入理解RE模块:Python中的正则表达式神器解析

在Python中,"re"是一个强大的模块,用于处理正则表达式(regularexpressions)。正则表达式是一种强大的文本模式匹配工具,用于在字符串中查找、替换或提取特定模式的文本。re模块提供了一系列函数和方法,使得在Python中使用正则表达式变得非常方便。下面是对re模块的详细讲解:导入re模块:在使用re模块之前,需要先导入它。可以使用以下语句导入re模块:importrere模块的核心函数和方法:re.match(pattern,string):尝试从字符串的开头匹配模式。如果匹配成功,返回一个匹配对象;否则返回None。re.search(pattern,string):在

c++ - 带有 enable_if 和重载的 SFINAE

我环顾四周,但无法找到解决我的具体问题的方法。我有代码:templatetypenamestd::enable_if::value||std::is_enum::value,std::string>::typeconvertToString(constTargument){returnstd::to_string(argument);}std::stringconvertToString(std::stringstring);代码应该做什么:对任何数字类型(int、float、double和ENum)使用模板版本,对其他任何类型使用std::string版本。代码本身编译得很好,但是当