草庐IT

Optional类

全部标签

c++ - std::optional 中不可复制的容器

我正在尝试将不可复制类型的(STL-)容器打包到std::optional,e。例如:classMyClass{MyClass(constMyClass&)=delete;};std::optional>optContainer;但是编译器(GCC7.2)提示error:useofdeletedfunction'MyClass::MyClass(constMyClass&)'{::new((void*)__p)_Up(std::forward(__args)...);}[...]note:declaredhereMyClass(constMyClass&)=delete;并在type_

c++ - 当我可以返回一个指针时,为什么要使用 boost::optional

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭6年前。Improvethisquestion如果我有一个find函数,有时可能无法找到所需的东西,我倾向于让该函数返回一个指针,这样一个nullptr指示该东西没有找到。例如Student*SomeClass::findStudent(/**somecriteria.*/)如果Student存在,返回一个指向找到的Student对象的指针,否则返回nullptr。我也看到boost::optional也为此目的而提倡。例如。When

c++ - 我可以使用 std::optional 进行错误处理吗?

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion使用C++17我们得到了std::optional这是表达可空类型的有用包装器。我可以用它来处理错误吗?这样做很有吸引力:optionalCompute(){//...computesomethingvalid...returnstd::nullopt;//error!}这会是一个不错的选择吗?返回空指针不一样吗?人们报告的问题是,如果发生错误,您会丢失一条消息。所以返回一些状态码可能会更

c++ - 有什么能阻止 std::optional::value_or() 有条件地 noexcept 吗?

这是value_or()的定义来自C++17标准:templateconstexprTvalue_or(U&&v)const&;Effects:Equivalentto:returnbool(*this)?**this:static_cast(std::forward(v));Remarks:Ifis_copy_constructible_v&&is_convertible_visfalse,theprogramisill-formed.(右值重载类似)value_or的效果被描述为等同于returnbool(*this)?**this:static_cast(std::forward

c++ - 如何防止 boost::optional<T> 被错误地构造为 0?

boost::optional(1.51)提供了一种构造对象的方法,这对我的用户来说非常危险,我想避免这种情况。假设我有自己的整数类,我想传递一个可选的此类整数并将其存储在某个类中:classmyint{public:intm_a;myint(intr_a):m_a(r_a){}};structmyclass{boost::optionalcontent;myclass(constboost::optional&arg):content(arg){}};现在,用户将如何使用该类:myclass(myint(13));//correctusemyclass(boost::none);//

c++ - 使用 boost::optional 时避免临时

boost::optional支持像这样的in_place构造:#include#includeclassFoo{inta,b;public:Foo(intone,inttwo):a(one),b(two){}};intmain(){boost::optionalfooOpt(boost::in_place(1,3));}一旦我们有了一个初始化的fooOpt,有没有办法在不创建临时对象的情况下为它分配一个新的Foo?类似的东西:fooOpt=boost::in_place(1,3);谢谢! 最佳答案 boost::可选#includ

c++ - 我如何在 C++ 中使用 std::optional?

我正在尝试使用std::optional但我的代码引发了错误。我指定了#include和编译器选项是-std=c++1z,-lc++experimental.如何使用std::experimental::optional?代码如下:#include#includestd::experimental::optionalmy_div(intx,inty){if(y!=0){intb=x/y;return{b};}else{return{};}}intmain(){autores=my_div(6,2);if(res){intp=res.value();std::cout错误信息:optio

c++ - 将 std::vector<boost::optional<double>> 转换为 std::vector<double>

我有一个std::vector>,foo说。在这个特定的例子中,我需要一个std::vector其他vector中的任何“可选”元素映射到新vector中的0。我是否缺少针对此问题的单线解决方案?另一种选择是不尽如人意std::vectorout(foo.size());for(auto&it:foo){out.push_back(it?*it:0.0);}我欢迎基于std::optional的解决方案,即使我还没有使用该标准。 最佳答案 std::transform解决方案:std::vectorout(foo.size());s

c++ - 为什么我不能用 optional<S> 构造 optional<T> (对于 S!=T)?

如果我们有std::experimental::optionalx;以下两行都不编译:std::experimental::optionaly;y=x;std::experimental::optionalz(x);...尽管在我看来这就像将int赋值给unsignedint一样有意义。为什么这行不通?也就是说,库没有为这种情况实现复制构造函数和赋值运算符,避免了哪些陷阱? 最佳答案 你不能这样做,因为std::experimental::optional没有适当的构造函数和赋值运算符重载。当然可以提供这样的接口(interface

kotlin - Kotlin 的 DAO 应该返回 Optional 还是 null?

在Kotlin/JPA之前,我曾经这样编写我的DAO层:publicinterfaceUserDaoextendsJpaRepository{OptionalfindBySsn(Stringssn);}在调用方,如果我想通过SSN找人或创建用户,我可以这样写:valuser=userDao.findBySsn(value).orElseGet{userDao.save(value)}效果很好,看起来很流畅。但由于Kotlin引入了null-safety,还有另一种惯用的方式(dao仍在Java中):publicinterfaceUserDaoextendsJpaRepository{O