草庐IT

vector_double

全部标签

c++ - 我可以在 VS2008 的 C 代码中使用 C++ vector 吗

我在vs2008中运行C代码。我很好奇我是否可以将此代码与C++代码混合 最佳答案 简短的回答是肯定的。但是,存在一些细微差别。C++通常支持C的很大一个子集。这意味着您几乎可以从C++代码中获得C中可用的任何内容(例如函数、库等)。从这一点开始,您有两个选择,一个简单,一个更难。选项#1-使用C++编译器。只需将您的代码视为C++。简单地说-使用C++编译器。选项#2-混合使用C和C++。您可以编写C代码并使用C++编译器对其进行编译。在需要使用C++组件的地方使用C-likeC++。例如,您的设置可能类似于以下内容:head1.

c++ - 是否可以使用互斥锁来锁定 vector 中的元素而不是整个 vector ?

是否可以使用互斥量来锁定vector中的元素而不是整个vector?例如,给定一个vectormyVec;将10个元素推回myVecfor(inti=0;ivector的每个元素将被多个线程异步更改。如何使用互斥锁只锁定myVec中的一个缓冲区,以便一个线程可以写入或读取一个元素;另一个可以同时读写另一个元素吗?谢谢 最佳答案 你想要的比你想象的更简单也更难:如果你的容器作为一个整体没有变化,即没有插入或删除,那么标准库容器已经提供了有限类型的线程安全,即允许不同的线程读取或修改不同的容器元素,即只要不超过一个线程访问任何给定元素。

c++ - R 数值 vector 列表 -> C++ 2d array with Rcpp

我主要使用R,但最终想使用Rcpp与一些接收和返回二维数值数组的C++函数交互。因此,为了开始使用C++和Rcpp,我想我只需要编写一个小函数,将我的可变长度数字vector的R列表转换为C++等效项,然后再返回。require(inline)require(Rcpp)test1=cxxfunction(signature(x='List'),body='usingnamespacestd;Listxlist(x);intxlen=xlist.size();vector>xx;for(inti=0;itest=as>(xlist[i]);xx.push_back(test);}retu

c++ - Stringstream 到 vector<int>

我想知道从std::stringstream中写入的最佳方式是什么进入vector.这是stringstream中内容的示例:"31#0053253803335342337"这是我得到的:intbuffer=0;vectoranalogueReadings;stringstreamoutput;while(output>>buffer)analogueReadings.push_back(buffer);然而,似乎发生的是,它读取第一件事,然后到达#00并返回0因为它不是数字。理想情况下,我想要的是,它达到#然后跳过所有字符直到下一个空格。这可以用标志或其他东西实现吗?谢谢。

c++ - C中double **和double (*)[2]的区别

double**和double(*)[2]有什么区别。如果我理解得很好,double**是指向double指针的指针,因此它可以是任意大小的二维数组,而double(*)[2]是指向double[2]数组的指针.那么如果是对的,如何才能成功传递给函数。例如:voidpcmTocomplex(short*data,double*outm[2])如果我传递double(*)[2]作为参数,我会收到以下警告:warning:passingargument2of‘pcmTocomplex’fromincompatiblepointertypenote:expected‘double**’but

C++ 用另一个 vector 填充一个 vector

我有两个vector,我想用第二个填充第一个。vector声明如下:vectorfirstVector;其中Vec3是一个具有floatx、y、z的结构。我试过通过分配喜欢这个:secondVector.assign(firstVector.begin(),firstVector.end());但是它停下来并提示说end()有问题。我也试过推回,但当然不行。正如我之前读到的,我应该用assign来做,但我不知道如何正确地解决它。编辑:insert和assign的报错信息是一样的:这个0x00000000...std::vector>*const[size]CXX0030:错误:无法计算

c++ - 如何将元素插入 std::unordered_map<int, vector<Object*>>

我正在尝试创建指向我的对象的指针数组的散列。散列键是对象类型的int,数组是要渲染的对象列表。我想做的是:unordered_map>drawQueue;drawQueue.clear();//newemptydrawqueuefor(...){drawQueue.at(type).push_back(my_obj);}所以我对STL东西的细微差别还不够熟悉,因为我得到一个异常,说out_of_bounds,这是当key不存在时发生的情况。所以我想我需要先创建key,然后添加到vector中:if(drawQueue.count(type)){//keyalreadyexistsdra

c++ - 多线程 vector

我正在使用C++开发一个项目,该项目使用自己创建的map来存储数据-从这个意义上讲,map更像是“地理”map,因此是图像。有不同的线程读取和写入它。map的数据存储在整数vector的标准vector中。它的大小不会改变,只是通过getter和setter函数改变某些像素的内容。我的问题如下:有时一切正常,但更多时候我得到损坏的图像,因为像素值改变符号或变得与它们应该的值完全不同。这可能是对像素的线程读/写访问的问题,如果是这样,我应该使用什么来代替标准vector?我曾尝试使用互斥锁来确保只有一个线程读取或写入vector,但是这些读/写操作经常发生,如果我在每次操作时都锁定vec

c++ - std::vector::operator[] 不测试类型

我有一个这样的结构:structVrtxPros{longidx;std::vectorpros;VrtxPros(constlong&_idx=-1,conststd::string&val=""):idx(_idx){if(!val.empty()&&val!="")pros.push_back(val);}};后来在代码中我这样使用它:longidx=1234;VrtxProsvp(2134,std::string("-1"));if(margin)vp.pros[0]=idx;编译器对此没有问题。我想知道,因为运营商应该提供引用。我couldnotfindstd::string

c++ - 具有 double 、 float 和整数数据类型的英特尔 MKL 矩阵产品性能

我正在试验英特尔MKL库,使用它们提供的Boost::uBLAS接口(interface)(包括mkl_boost_ublas_matrix_prod.hpp)执行矩阵乘法。我的数据只是整数,所以我尝试将我的矩阵模板类型更改为int并且性能下降,这似乎主要是由于代码仅使用单个CPU内核而不是我可用的12个。我在MKL文档中找不到任何内容来解释为什么整数没有使用MKL的OpenMP多线程功能(我猜他们根本没有使用MKL?)。此外,与float相比,我发现double的性能下降了50%。问题:为什么float和double之间存在差异?为什么我不能使用整数?这是我从下面的代码中得到的结果: