草庐IT

some_function_returning_an_option

全部标签

c++ - std::optional<std::reference_wrapper<T>> - 可以吗?

是std::optional>是否符合C++17的标准(或草案)?标准明确指出,引用类型的std::optional格式错误。但它是否包括reference_wrapper? 最佳答案 是的。那没问题。它不包括reference_wrapper因为reference_wapper不是引用类型。只有实际的引用类型是不允许的。 关于c++-std::optional>-可以吗?,我们在StackOverflow上找到一个类似的问题: https://stackov

c++ - 将成员函数作为参数传递给其他成员函数 (C++ 11 <function>)

这个问题在这里已经有了答案:HowcanIpassamemberfunctionwhereafreefunctionisexpected?(9个回答)关闭7天前。假设我有一个包含三个成员函数的类,如下所示:#include#includeclassClassName{public:doubleadd(doublea,doubleb);doubleintermediate(doublea,doubleb,std::functionfunc);doublecombiner(doublea,doubleb);};doubleClassName::add(doublea,doubleb){re

c++ - 为什么忽略 std::optional 的强制转换运算符?

这段代码#include#includestructfoo{explicitoperatorstd::optional(){returnstd::optional(1);}explicitoperatorint(){return2;}};intmain(){foomy_foo;std::optionalmy_opt(my_foo);std::cout>(my_foo);std::coutproducesthefollowingoutputconstructor:2static_cast:2在Clang4.0.0和MSVC2017(15.3)中。(让我们暂时忽略GCC,因为在这种情况下它

c++ - 沮丧 : why: ‘A’ is an inaccessible base of ‘B’ ?

与此错误消息的其他示例不同,我已经有一个指向A的指针并且想要检索实际的子类。这种安排是一些C++包装的C代码的一部分A是一些PODC结构(whatswhy没有动态转换)而test是C中的一些回调调用C++功能并检索应使用强制转换的正确对象。但是为了防止C++用户代码弄乱C-Baseclass,我希望继承protected。MSVC不会提示这个但g++会提示!?从标准的角度来看,哪一个是正确的?为什么?#includeusingnamespacestd;//plainCstructurestructA{inti;};//someC++WrapperclassstructB:protect

c++ - std::function 是否比自动存储 lambda 函数重

我听说在处理lambda函数时,std::function的成本比auto高。有效的现代c++item5。我想要的是通过一些示例代码阐明为什么std::function使用的内存比auto更多的机制。有人可以帮助我吗?编辑classWidget{public:Widget(inti):i_(i){}booloperatori_;}intvalue()const{returni_;};private:inti_;intdummy_[1024];};intmain(){//performancedifferencebetweenautoandstd::function{autoless1=

《Learning from Context or Names?An Empirical Study on Neural Relation Extraction》论文阅读笔记

代码原文地址预备知识:1.什么是对比学习?对比学习是一种机器学习范例,将未标记的数据点相互并列,以教导模型哪些点相似,哪些点不同。也就是说,顾名思义,样本相互对比,属于同一分布的样本在嵌入空间中被推向彼此。相比之下,属于不同分布的那些则相互拉扯。摘要神经模型在关系抽取(RE)的基准任务上表现出色。但是,我们还不清楚文本中哪些信息对现有的RE模型的决策有影响,以及如何进一步提升这些模型的性能。为了解决这个问题,本文实证地分析了文本中两个主要的信息源:文本上下文和实体提及(名称)对RE的作用。本文发现,虽然上下文是预测的主要依据,但RE模型也高度依赖于实体提及中的信息,其中大多数是类型信息;以及现

c++ - 是否允许在 requires 表达式中为 return-type-requirement 指定类型?

看看这个简单的概念示例:templaterequiresrequires(Tt){{t+t}->bool;}voidfn(){}intmain(){fn();}这里,我使用bool作为return-type-requirement的type-constraint。当前稿says:type-constraint:nested-name-specifieroptconcept-namenested-name-specifieroptconcept-name所以type-constraint必须是一个concept-name。bool(或任何类型)是否允许作为概念名称?如果是,那是什么意思,

c++ - 首选哪个,return const double& OR return double

给定以下场景,以下哪一项是首选。m_state是一个成员评价者,而不是局部变量。classC{private:doublem_state;public:doublestate()const{returnm_state;}//returnsdoubledouble&state(){returnm_state;}}===========================================classC{private:doublem_state;public:constdouble&state()const{returnm_state;}//returnsconstdouble&

c++ - 消除对采用 std::functions 的函数的调用的歧义

下面的代码不能在gcc4.5上编译,因为对foo的调用不明确。消除歧义的正确方法是什么?#include#includeusingnamespacestd;voidfoo(std::functiont){t(1,2);}voidfoo(std::functiont){t(2);}intmain(){foo([](inta,intb){cout 最佳答案 最好的方法是显式创建一个std::function正确类型的对象,然后将该对象传递给函数:std::functionfunc=[](inta,intb){cout或内联:foo(st

c++ - boost ASIO async_read_some

我在实现一个简单的TCP服务器时遇到了困难。以下代码摘自boost::asioexamples,准确地说是“Http服务器1”。voidconnection::start(){socket_.async_read_some(boost::asio::buffer(buffer_),boost::bind(&connection::handle_read,shared_from_this(),boost::asio::placeholders::error,boost::asio::placeholders::bytes_transferred));}voidconnection::ha