草庐IT

rdbg_std_amd

全部标签

c++ - 如何使用 libjpeg 从 std::istream 读取 JPEG?

libjpeg可以从FILE*或缓冲区中读取JPEG数据。我的数据来自std::istream。我可以将整个std::istream读入缓冲区以与libjpeg一起使用,但如果可能的话,我宁愿让libjpeg直接从std::istream中读取。如何做到这一点? 最佳答案 您只需要为您的istream提供包装器。定义一个结构体,例如structJpegStream{jpeg_source_mgrpub;std::istream*stream;bytebuffer[4096];}然后需要四种方法对流进行操作:voidinit_sour

c++ - 在 std::auto_ptr 的构造函数中使用 `explicit` 关键字有什么原因吗?

这是用于在VS2008编译器中从标准指针构造std::auto_ptr对象的构造函数。templateclassauto_ptr{public:explicitauto_ptr(_Ty*_Ptr=0)_THROW0():_Myptr(_Ptr){}private:_Ty*_Myptr;};explicit是否有任何特殊原因?上面使用关键字?换句话说,为什么我不能初始化auto_ptr与std::auto_ptrptr=newClassA;? 最佳答案 因为否则您可能会无意中执行以下操作:voidfoo(std::auto_ptrp)

c++ - 如何将 char 数组放入 std::string

我分配了一个char数组然后我需要将它作为一个字符串返回,但我不想复制这个char数组然后释放它的内存。char*value=newchar[required];f(name,required,value,NULL);//fillthearraystrResult->assign(value,required);delete[]value;我不想像上面那样做。我需要将数组放在std字符串容器中。我该怎么做?编辑1:我知道我不应该这样做,并且该字符串不是为此目的而设计的。MB有人知道我可以使用的char数组的另一个容器实现吗? 最佳答案

c++ - 如何将所有对从一个 std::map 移动到另一个

假设我有以下内容:std::mapm1;std::mapm2;从m1移动所有键/值对的最直接方法是什么?进入m2?我希望:m1在此操作后为空m2最初可能有对m2中与m1不具有相同key的那些对应该单独保留m2中与m1具有相同key的那些对应该被m1的对覆盖我需要来自的调用组合吗??解决方案JamesKranze的解决方案满足我的要求。for(constauto&p:m1)m2[p.first]=p.second;m1.clear();JoachimPileborg的建议仅在m2和m1没有相同的键时才有效(即m2的值不会被m1的相同键的值覆盖)std::move(m1.begin(),m

c++11:为什么 std::forward 中的 static_assert 是必需的?

在move.h中,forward有两个重载templateconstexpr_Tp&&forward(typenamestd::remove_reference::type&__t)noexcept{returnstatic_cast(__t);}templateconstexpr_Tp&&forward(typenamestd::remove_reference::type&&__t)noexcept{static_assert(!std::is_lvalue_reference::value,"templateargumentsubstituting_Tpisanlvalueref

c++ - 微小的 SSE addpd 循环比 AMD Phenom II 上的标量稍慢?

是的,我读了SIMDcoderunsslowerthanscalarcode.不,这不是真正的重复。我使用二维数学已有一段时间了,并且正在将我的代码库从C移植到C++。我在使用C时遇到了一些问题,这意味着我确实需要多态性,但那是另一回事了。不管怎样,我之前考虑过这个,但它提供了一个使用2Dvector类的绝好机会,包括常见数学运算的SSE实现。是的,我知道那里有图书馆,但我想自己尝试一下以了解发生了什么,而且我没有使用比+=更复杂的东西。.我的实现是通过,用一个union{__m128dss;struct{doublex;doubley;}}SSE似乎很慢,所以我查看了它生成的ASM输

c++ - std::vector 与 std::array 性能对比

我正在查看新的计时库(C++11)并尝试使用它。我写了以下两个程序:vector.cpp#include#include#includeintmain(){std::vectorvector(1000000,0.);autostart=std::chrono::high_resolution_clock::now();for(inti(0);i(end-start).count()数组.cpp#include#include#include#includeintmain(){std::arrayarray;std::fill(array.begin(),array.end(),0.);

c++ - std::async 不并行化任务

在此代码段中使用C++11std::async:intfoo(){::sleep(2);return123;}intmain(){futurer1(async(foo));intr2=foo();cout它产生正确的结果,但连续运行两个foo(整个应用程序运行4秒)。编译为:g++-std=gnu++11-O2foo.cc-lpthread(Ubuntu12.1064位,gcc4.7.2) 最佳答案 您可能需要添加launchpolicystd::launch::async的:std::async(std::launch::asyn

c++ - 使用 std::vector 的稀疏矩阵性能低下

我正在尝试实现MATLAB函数的功能sparse.在稀疏矩阵中的特定索引处插入一个值,这样:如果矩阵中已经存在具有相同索引的值,则添加新值和旧值。否则将新值附加到矩阵。addNode函数执行正确,但问题是它非常慢。我在循环中调用此函数大约100000次,程序运行时间超过3分钟。而MATLAB在几秒钟内完成了这项任务。有没有办法优化代码或者用STL算法代替我自己的函数来实现我想要的?代码:structSparseMatNode{intx;inty;floatvalue;};std::vectorSparseMatrix;voidaddNode(intx,inty,floatval){Sp

c++ - 如何将参数的 a::std::vector 绑定(bind)到仿函数?

我正在努力让这个程序正确编译:#include#includeintf(inta,intb){::std::coutRbind_vec(R(*f)(),constV&vec,intidx=0){returnf();}templateRbind_vec(R(*f)(Arg1,ArgT...),constV&vec,intidx=0){constArg1&arg=vec[idx];autocall=[arg,f](ArgT...args)->R{return(*f)(arg,args...);};returnbind_vec(call,vec,idx+1);}intfoo(){::std: