草庐IT

std-ranges

全部标签

c++ - 如果我们将 std::cout 应用于指向成员的指针,我们将收到什么值

我们可以通过应用获取位于内存中的对象的地址表示std::cout我正在尝试对指向成员的指针类型执行相同的操作。#includeusingnamespacestd;structX{boolb;inta;};intX::*a=&X::a;boolX::*b=&X::b;Xx;intmain(){coutDEMO你看我收到了1。1是什么?或者我必须提到一个pointer-to-member只是一种不直接绑定(bind)到“只是”指针的类型吗? 最佳答案 因为operator没有过载直接指向成员的指针,a和b隐式转换为bool,存在过载。该

c++ - 简单但频繁使用 std::stringstream 是否过早悲观?

我有一个简单的场景。我需要将两个C字符串连接成一个std::string。我决定采用以下两种方式之一:方案一voidProcessEvent(charconst*pName){std::stringfullName;fullName.reserve(50);//Ensureminimalreallocationsforsmalleventnames(50isanarbitrarylimit).fullName+="com.domain.events.";fullName+=pName;//UsefullNameasneeded}解决方案2voidProcessEvent(charcon

c++ - std::vector 本身的地址稳定吗?

如果我获取std::vector的地址,并且它在插入元素后重新分配,我可以假设它的地址没有改变吗?谢谢。 最佳答案 是的,在C++中你可以安全地假设。但是,第一个元素的地址&x[0]可以改变,那些地址是不一样的。编辑:当然其他元素的地址也是一样。顺便说一下,第一个元素的地址是否可能保持或多或少的稳定取决于whetherornotthegrowthfactorofthearrayislessthanthegoldenratio。,这是了解IMO的一个非常酷的事实。 关于c++-std::v

c++ - std::unique_lock::release 的用例是什么?

在什么情况下会使用std::unique_lock的release方法?我错误地使用了release方法而不是unlock方法,我花了一段时间才明白为什么下面的代码不起作用。#include#include#include#include#includestd::mutexmtx;voidfoo(){std::unique_locklock(mtx);std::coutthreads;for(inti=0;i 最佳答案 它在thisanswer中有很好的用途其中锁定状态的所有权明确地从函数本地unique_lock转移到外部实体(通

c++ - `std::string::begin()`/`std::string::end()` 迭代器失效?

#include#includeintmain(){std::strings="abcdef";std::strings2=s;autobegin=const_cast(s2).begin();autoend=s2.end();std::cout此代码将begin()const的结果与end()的结果混合在一起。这些函数都不允许使任何迭代器失效。但是我很好奇end()不使迭代器变量begin无效的要求是否实际上意味着变量begin可用于结束。考虑一个C++98,std::string的写时复制实现;非常量begin()和end()函数导致复制内部缓冲区,因为这些函数的结果可用于修改字符

c++ - 无法使用 MPI_Send 和 MPI_Recv 发送 std::vector

我正在尝试使用MPI发送和接收函数发送std:vector但我没有到达任何地方。我收到类似的错误FatalerrorinMPI_Recv:Invalidbufferpointer,errorstack:MPI_Recv(186):MPI_Recv(buf=(nil),count=2,MPI_INT,src=0,tag=0,MPI_COMM_WORLD,status=0x7fff9e5e0c80)failedMPI_Recv(124):Nullbufferpointer我尝试了多种组合A)就像用来发送数组的..std::vectorm_image_data2;//definitionof

c++ - std::unique_lock 和 std::condition_variable 如何工作

我需要弄清楚lock和condition_variable是如何工作的。在此处的-稍微修改过的代码中cplusplusreferencestd::mutexm;std::condition_variablecv;std::stringdata;boolready=false;boolprocessed=false;voidworker_thread(){//Waituntilmain()sendsdatastd::unique_locklk(m);cv.wait(lk,[]{returnready;});//afterthewait,weownthelock.std::coutlk(m

c++ - 如何避免 std::vector 在(重新)分配时复制?

我刚刚在向其添加新元素时遇到了std::vector的问题。似乎当你试图向它添加更多元素时,它需要分配更多空间,它通过复制它当前拥有的最后一个元素所有元素来实现。这似乎假设vector中的任何元素都是完全有效的,因此复制总是成功的。在我们的例子中,这不一定是真的。目前我们可能在vector中有一些遗留元素,因为我们选择不删除它们,它们是有效的对象,但它们的数据不能保证有效的行为。对象有守卫,但我从未考虑过向复制构造函数添加守卫,因为我认为我们永远不会复制无效对象(vector强制):CopiedClass::CopiedClass(constCopiedClass&other):mem

c++ - std::unique_ptr 试图引用已删除的函数

我已经使用Unity一段时间了,然后回来使用VisualStudio2015做一些C++。我遇到了这个类定义classA{public:A();virtual~A();A(constA&)=delete;A&operator=(constA&)=delete;private:…}这个类是动态分配的,如下所示:ObjPtrobj=ObjPtr(newA());哪里ObjPtr是定义的类型,看起来像:typedefstd::unique_ptrobjPtr;并将这些创建的对象添加到std::vector使用std::move.有一次,我需要遍历对象列表,如果我找到满足我条件的对象,请保留一

c++ - 普通默认可构造的 std::optional 和 std::variant

可以设计吗std::optional(当前std::experimental::optional)以这种方式,对于普通的默认可构造类型T对应std::optional也是默认可构造的吗?同样的问题重新阅读std::variant及其积分判别器。我自己的回答是:“不行,不能这么设计,因为如果对象有自动存储期,或者是非reinterpret_cast-ed,默认初始化时得到的它的整数鉴别器的值是不确定的-零初始化存储。”要求用户每次都进行值初始化在我看来是不允许的。 最佳答案 您的回答是正确的:不能。规范要求在默认构造时将其“初始化标志