草庐IT

C_Func_using_Func_ptr

全部标签

c++ - C++ 中的异常处理 : Throwing a double when using "throw(int)"

下面的程序总是输出“Error:double10.2”。我不明白为什么。根据我的说法,如果fun1()只允许抛出int,那么程序应该要么(1)崩溃(2)或者把double改成int然后throw。这意味着,输出应该是“Error:int10”。然而,情况并非如此。谁能解释一下??voidfun1()throw(int){cout 最佳答案 您的编译器不符合标准。根据标准,您的程序应以调用std::unexpected结束。在让double异常转义fun1之后。也就是说-不要使用异常规范。它们已被弃用且无用。

c++ - 如何传递 unique_ptr<T> 代替原始 *output* 指针参数?

我在外部库中有一个预先存在的函数,它看起来像这样;boolCreateTheThing(MyThing*&pOut);简而言之;我给它一个原始指针(通过引用),函数分配内存并将我的指针分配给新分配的对象。当函数返回时,我有责任在我完成后释放内存。显然,我想将此结果存储到unique_ptr中,并避免使用手册delete.我可以创建一个临时原始指针以用于API调用,并将其传递到unique_ptr的构造函数中;MyThing*tempPtr;CreateTheThing(tempPtr);unique_ptrrealPtr=unique_ptr(tempPtr);还有比这更直接的方法吗?

c++ - 为什么类 std::weak_ptr 没有运算符 <?

这个问题在这里已经有了答案:HowcanIuseastd::mapwithstd::weak_ptraskey?(2个答案)关闭4年前。我在map中使用弱指针作为键。然而,当我尝试编译时,我得到了丑陋的消息,我将其解释为我缺少std::weak_ptr的比较运算符,这显然是std::map所必需的,因为它根据以下命令对其元素进行排序键值。但是,现在weak_ptr类是一个智能指针类型类,因此可以使用指向某些托管数据的指针。这个类不提供operator在这里,您的见解将不胜感激。感谢期待。

c++ - 初始化 boost::scoped_ptr 数组的正确方法?

我有一个类,其中有一个范围指针数组,这些指针指向没有默认构造函数的对象。我发现“初始化”它们的唯一方法是像这样使用swap():classBar{Bar(char*message){};}classFoo{boost::scoped_ptrarr[2];Foo(){arr[0].swap(boost::scoped_ptr(newBar("ABC")));arr[1].swap(boost::scoped_ptr(newBar("DEF")));};}这感觉有点冗长和笨拙。我错过了更聪明的方法吗? 最佳答案 arr[0].reset

vscode出现Specifies folder path to the JDK(17 or recent)used to launch the Java Language Server解决方案

  大家好,我是爱编程的喵喵。双985硕士毕业,现担任全栈工程师一职,热衷于将数据思维应用到工作与生活中。从事机器学习以及相关的前后端开发工作。曾在阿里云、科大讯飞、CCF等比赛获得多次Top名次。现为CSDN博客专家、人工智能领域优质创作者。喜欢通过博客创作的方式对所学的知识进行总结与归纳,不仅形成深入且独到的理解,而且能够帮助新手快速入门。  本文主要介绍了vscode出现SpecifiesthefolderpathtotheJDK(17ormorerecent)usedtolaunchtheJavaLanguageServer.ThissettingwillreplacetheJavae

c++ - 这是在 C++11 中使用 unique_ptr 和移动语义实现 pimpl 的正确方法吗

我还没有看到同时使用unique_ptr和移动语义的pimpl示例。我想向STL派生容器添加一个CHelper类,并使用pimpl隐藏CHelper的功能。这样看起来对吗?派生.hclassCDerived:publicset,publicCHelper{//...};`Helper.h//derivedcontainersneedtosupportbothcopyandmove,soCHelperdoestooclassCHelper{private:classimpl;unique_ptrpimpl;public://---default:needbothcotr&cotr(com

c++ - 与普通指针相比,按值传递 `unique_ptr` 是否会降低性能?

Commonwisdomisthatstd::unique_ptrdoesnotintroduceaperformancepenalty(andnotamemorypenaltywhennotusingadeleterparameter),但我最近偶然发现了一个讨论,该讨论表明它实际上引入了一个额外的间接寻址,因为unique_ptr无法在具有ItaniumABI的平台上的寄存器中传递。发布的示例类似于#includeintfoo(std::unique_ptru){return*u;}intboo(int*i){return*i;}Whichgeneratesanadditional

c++ - 从 unique_ptr<T[]> 初始化 shared_ptr<T>

[跟进this问题]最近我一直在处理指向C风格数组的智能指针。我最终完成了推荐的事情并改为使用指向vector的智能指针,但在那段时间里,我得到了一些建议:不要使用shared_ptr对象来管理最初使用make_unique创建的数组因为它不会调用delete[]而是delete.这对我来说似乎不合逻辑,我检查了两个Coliru和标准:这段代码:#include#includeintmain(){std::coutmyUnique(customArrayAllocator(4),customArrayDeleter);std::coutmyShared=std::move(myUniq

c++ - 具有自定义删除器的 unique_ptr 构造函数被删除

这个例子在gcc4.8.3下编译和运行良好:#include#include#includeintmain(){autostr=newconstchar[6]{'h','e','l','l','o','\0'};std::unique_ptr>u_ptr(str,[](constchar*s){delete[]s;});std::cout但是当我尝试使用VisualStudioProfessional2013时,它无法编译(提示函数已删除)。这在VisualStudio2013中还不可能吗?还是我的示例代码有误而gcc忽略了我的错误?错误是:main.cpp(8):errorC2280

c++ - 有没有权威的方法来防范c++中的 "use after move"错误?

我发现开发人员很容易犯这些错误。是否有避免这种情况的最佳实践或权威方法?是否有适用于多个平台的编译器标志或提示? 最佳答案 一个有效的经验法则:永远不要使用std::move或std::forward并且永远不要类型转换为右值(或通用)引用。如果您从不从变量或引用移动,那么您就不会犯在之后使用它的错误。这种方法显然有一个缺点,因为这些实用程序在某些情况下可用于在移动足够时将拷贝转换为移动;更不用说必要的情况了。适用于您自己的类型的方法:将断言添加到成员函数中,以验证实例是否已从中移出,并依赖它们在测试期间触发。“移动”状态将需要存储