草庐IT

pybind11

全部标签

C++11 VS2013类POD成员初始化

我到处都在寻找对此的解释,但我做空了。我从VS2013v120平台工具集中看到了这种行为,但是当我将工具集设置为v90(VS2008工具集)时,一切都未初始化。我相信这是由于C++11中的一些变化,但也可能是v120平台工具集的异常。谁能解释一下C++/C++11级别的情况?也就是说,为什么b被清零了?为什么j也没有归零?(即为什么结构的行为与类的行为不同)此外,我知道我输出数据的方式是未定义的行为,请忽略它。在这里发布这种方式比调试器窗口更容易。这是在32位上运行的,因此指针的大小与unsignedint相同。考虑以下代码:#includeclassFoo{public:inta,*

C++11 具有非原子变量的原子内存顺序

我不确定c++11中原子变量的内存排序保证如何影响对其他内存的操作。假设我有一个线程定期调用写入函数来更新值,另一个线程调用读取函数来获取当前值。是否保证d=value;的效果不会在a=version;的效果之前看到,而会在b=的效果之前看到版本;?atomica{0};atomicb{0};doubled;voidwrite(intversion,doublevalue){a=version;d=value;b=version;}doubleread(){intx,y;doubleret;do{x=b;ret=d;y=a;}while(x!=y);returnret;}

c++ - C++11/C++14 中的自动和大括号初始化

这个问题在这里已经有了答案:Differentcompilerbehaviorforexpression:autop{make_pointer()};(1个回答)关闭7年前。当我用clang和gcc编译下面的代码时T推导不同。#include//forclang//toseehowTisdeduced(formcompilererror).templatevoidfoo(T);intmain(){autovar1{2};foo(var1);}这是我得到的。clang3.6(c++11/c++14)gcc4.9(c++11/c++14)T=std::initializer_listgcc

c++ - 在 C++ 11 中创建动态二维矩阵的好方法

我已经知道如何使用new创建动态二维矩阵并使用delete释放它。由于C++11具有许多新的内存特性,例如unique_ptr、array容器等;什么是创建二维矩阵的好方法,这样就不需要使用delete运算符显式释放矩阵? 最佳答案 最简单的方法之一是使用vector的vectorconstintN=10;constintM=10;vector>matrix2d(N,vector(M,0));//10x10zero-initializedmatrixmatrix2d[0][0]=42;您当然可以使用单个vector并将其包装到访问器

c++ - 在 C++11 之前移动语义是如何解决的?

我最近一直在阅读移动语义以及它是如何被引入到C++11中的。主要要点是,通过“窃取”指向临时对象的指针来创建对象,程序可以变得更有效率。这比深拷贝临时对象来创建新对象要高效得多。在C++11(及更高版本)中,这是通过使用右值引用来实现的。所有临时对象(在程序内存中没有已知位置的对象)都被视为右值。具体来说,现在可以重载类构造函数以接受右值引用。所以我很好奇,在C++11之前,这个“昂贵的临时对象拷贝”问题是如何解决的? 最佳答案 完成此操作的主要方式是通过std::swap。std::swap可以重载/专门用于可以比默认的“通过临时

Windows11安装运行Linux(Ubuntu)

一、安装windows支持输入windows打开界面选择虚拟机监控程序平台、适用于linux的子系统、虚拟机平台在Windows系统中,"虚拟机平台"和"虚拟机监控程序平台"是两个与虚拟化相关的功能,但它们各自有着不同的作用和用途。虚拟机平台(VirtualMachinePlatform):这个功能允许你在Windows操作系统上运行其他操作系统作为虚拟机。通过使用虚拟机平台,你可以创建、运行和管理各种类型的虚拟机,并在这些虚拟机中安装和运行不同的操作系统和应用程序。这个功能通常与虚拟化软件(如Hyper-V、VirtualBox、VMware等)一起使用,以提供对虚拟机的支持和管理。虚拟机监

C++ 11新特性之week_ptr

概述        在C++11标准中,智能指针的引入极大地提升了内存管理的安全性和便利性。除了已经广为人知的shared_ptr和unique_ptr之外,还有一个重要但相对较少被单独提及的智能指针类型——std::weak_ptr。std::weak_ptr是C++11引入的一种弱引用智能指针,它不拥有所指向对象的所有权,而是对shared_ptr持有的对象提供一种非拥有但可观察的访问方式。weak_ptr主要用于打破共享所有权循环引用的问题,防止出现内存泄漏。工作原理        1、不增加引用计数。        当创建一个weak_ptr时,它不会增加其所指向的对象的引用计数。这意

c++ - C++11 中具有 C 链接的复杂类型

我需要将C库的header包含到我的C++11代码中。现在,header提供的例程和数据结构到处都涉及大量doublecomplex。例如,#include//..typedefstructparameters{//...doublecomplexVud;}parameters;//...doublecomplexpolylog(intn,intm,doublex);我将这个文件放入我的C++11源代码中,用extern"C"{#include"include.h"}包装(不管你信不信,这就是实际的文件名)。如果我添加了-std=c++11,g++(尝试过4.7.3和4.8.2)和cl

c++ - C++11 中的 BOOST scoped_lock 替换

我面临这样一种情况,我必须用C++11中的等效项替换BOOSTscoped_lock。在visualstudio2013下。由于c++11不支持scoped_lock,我不确定下面的替换代码是什么。我应该选择lock_guard还是try_lock?boost::mutex::scoped_lockobjectLock(ObjectVectorMutex,boost::try_to_lock);if(objectLock){//...}在代码中我有以下“等待”语句if(ObjectsCollection.empty()){//Thisiswherewewaittilsomethingi

c++ - 在 C++11 中使用不带托管共享指针的 shared_from_this()

假设我有一个类是enable_shared_from_this的子类。这个基类的文档说在调用shared_from_this之前应该有一个拥有这个类的共享指针。使用new分配类并调用shared_from_this来管理对象是否安全? 最佳答案 正如其他用户已经提到的,在不属于shared_ptr的实例上调用shared_from_this将导致未定义的行为(通常是异常,但也有没有保证)。那么,为什么还要一个答案呢?因为我自己做了一次同样的问题并得到了几乎相同的答案,然后我开始为另一个问题而苦苦挣扎,这个问题紧随其后-我如何保证所有