草庐IT

C_Func_using_Func_ptr

全部标签

c++ - 动态分配数组的 unique_ptr 替代方案

我写了一个类,它必须与一些需要一些C风格数组(或至少指向第一个元素的指针)作为参数的旧代码接口(interface)。这些数组是我类的成员,它们特别大(50kb)所以我想把它们放在堆上,这样我类的对象在堆栈上就不会很大。我非常相信使用资源管理对象,所以我宁愿自己不在堆上管理这些数组。我发现使用unique_ptr的效果特别好。例如:std::unique_ptrsomeArrayName并使用:someArrayName(newSOMETYPE[someLargeSize])在我的构造函数的初始化列表中。这允许我使用.get()将它们用作常规C数组需要它作为参数的函数的方法,我不必自己

c++ - 我什么时候需要使用 std::async(std::launch::async, func()) 而不是 func()?

我不明白使用std::async的原因与std::lauch::async标志,而不是简单地调用传递给std::async的函数.是否有任何特价保证? 最佳答案 根据thedocumentation,是一个只接受函数及其参数的重载。您正在使用接受更具体的策略的重载。async(f,args...)等同于async(std::launch::async|std::launch::deferred,f,args...),其中两个标志的存在将函数是否简单地与当前调用堆栈分离(推迟到第一个非定时等待函数的执行;这称为惰性求值),或者实际上是

c++ - 为什么 list<unique_ptr> 中的 unique_ptr 的 std::move() 没有真正 move 它?

usingPtr=std::unique_ptr;Ptrf(boolarg){std::listlist;Ptrptr(newint(1));list.push_back(std::move(ptr));if(arg){Ptr&&obj1=std::move(list.front());//Here|obj1|and|list.front()|stillpointtothesamelocation!list.pop_front();returnstd::move(obj1);}else{Ptrobj2=std::move(list.front());list.pop_front();r

keil5【问题解决】提示:Target ‘LED‘ uses ARM-Compiler ‘Default Compiler Version 5‘ which is not available

文章目录1、问题描述:2、问题解决:2-1、原因分析:2-2、下载CompilerVersion5编译器2-3、安装CompilerVersion5编译器2-4、导入CompilerVersion5编译器的路径:===============================================1、问题描述:keil5选择ARMCompiler:CompilerVersion5,提示显示Miss:CompilerVersion5,编译之后提示:***Target‘LED’usesARM-Compiler‘DefaultCompilerVersion5’whichisnotavaila

c++ - 将 unique_ptr 的 vector 传递给对象。 vector 成为成员变量。正确的做法?

我将称之为“所有者”的一个对象在其生命周期内拥有数据对象vector的明确所有权。这些存储为unique_ptr的vector。一个对象/类,称为“Output”,需要在许多不同的方法中查看这些数据对象,因此某种引用/指针/变量是“Output”的成员变量.Output在其构造函数中接收数据对象的vector。我想到了三种方法来实现这一点。最好的方法是什么?选项1-“输出”对象将数据vec存储为常量引用:classOutput{//outputwantsthedata:public:Output(std::vector>const&in):my_lot_of_data(in){};st

c++ - 使用 shared_ptr<void> 初始化结构

我一直遇到一个错误nomatchingconstructorforinitializationof'std::shared_ptr'这是有道理的,但我不知道从哪里开始。这是我正在使用的。#includestructContainer{inttype;std::shared_ptrpayload;Container(intt,constvoid*p):type(t),payload(p){}};intmain(){return0;}我正在尝试使用shared_ptr制作一个通用容器类型为void.我打算对类型进行切换,然后将有效负载转换为适当的类型。我想我可以做类似Containerct

c++ - 具有 unique_ptr 作为成员的 C++ 模板的构造函数失败

当类模板包含指向另一个类的unique_ptr时,该类的构造函数不会将unique_ptr移动到新对象中。使用相同的类,但没有模板,构造函数按预期生成对象。#includeclasstest1{public:std::strings_;test1(std::strings):s_(s){};};classtestu{public:std::unique_ptrus_;testu(std::unique_ptrus):us_(std::move(us)){};};templateclasstestt{public:std::unique_ptrus_;testt(std::unique_

c++ - 什么是 A B::* func() 定义?

一个现已删除的问题与此类似:structA{};structB{Aread();};AB::*read(){returnA{};}这段代码会报错:error:cannotconvert‘A’to‘AB::*’inreturnreturnA{};正如我们所见,这不是read()的类外定义,而是定义了一个返回AB::*的非成员函数.在这种情况下,AB::*到底是什么? 最佳答案 AB::*表示“指向B的数据成员,类型为A。例如:structB{Ax;};...Bb;AB::*ptr=&B::x;//ptristhevariabledec

c++ - 如何启用 _USE_UNIX98 (Gcc/C++ v2.96)

我有一个在实际编译器中运行的C++应用程序(我用eclipse编译它)。现在,我需要在Redhat7.3上使用Kdevelop在非常旧的编译器版本(gcc/c++v2.96)上编译它。当我编译应用程序时,出现以下错误:swprintfundeclared。它包含wchar.hheader,但我在RH7.3操作系统中看到了此文件,并且仅在声明了__USE_UNIX98__USE_ISOC99时才声明此函数。如何启用__USE_UNIX98? 最佳答案 GNUlibc使用特殊的系统头文件定义了应该在其所有头文件中启用的功能.如果您定义适

c++ - 用于在 auto_ptr 和 unique_ptr 之间切换的宏

在一个仍然使用C++11之前版本的项目中,我想通过使用C++11编译器进行编译并修复错误来为切换准备源代码。它们包括std::auto_ptr的实例替换为std::unique_ptr必要时,用std::move()包裹智能指针一些0和NULL替换为nullptr现在我想切换回C++之前的编译器并编写一个可以切换回更改的宏,这样,当最后的编译器切换时间到了时,我只需删除宏。我试过了#ifndefHAVE_CXX11#definenullptrNULLnamespacestd{#defineunique_ptrauto_ptr}#endif(使用exvector与智能指针一起使用的示例类