草庐IT

std-ranges

全部标签

java - 将 std::unique_ptr 传递给 JNI

我正在用JNI包装一些C++代码,偶然发现了以下工厂函数:std::unique_ptrcreate_metric_planner(*arguments*)我需要将此函数创建的规划器的引用传递回Java以供以后使用,但我很困惑a)如何将其传回,以及b)一旦它被传递下去会发生什么。通常情况下,我都是这样过去的:Director*DIRECTOR=newDirector(arguments);return(jlong)DIRECTOR;它的效果非常好。有人可以解释当使用返回此类指针的工厂函数而不是普通构造函数时使用JNI引用对象的类似过程吗? 最佳答案

c++ - std::fstream 和 Boost Iostreams 库之间的区别

我是BOOST库的新手。今天看到一小段代码,其中读写PGM格式图片是用BoostIostreamsLibrary实现的。随着我对STL越来越熟悉,我可以很容易地看出std::fstream可以完成同样的工作。那么我的问题是,在这样一个简单的读写PGM图像的应用程序中使用Boost库有什么意义呢?此外,我想知道在什么情况下最需要BOOSTIostreams库。谢谢! 最佳答案 来自std::fstreamreference:fstreamprovidesaninterfacetoreadandwritedatafromfilesasi

c++ - 使用 std::cout 一次而不是多次显示相同数量的数据是否更有效?

例如,像这样显示这些变量会不会更节省内存:std::cout而不是这个:std::cout当然,我并不是真的担心两行代码..但我正在努力学习更有效地编写代码谢谢 最佳答案 将其设为单个语句理论上会更快,因为编译器可以更自由地重新安排参数评估的顺序。但是,这是在谈论0.00000000000001%的差异,毫无意义。不要关心这个-瓶颈在控制台本身。无论如何,列对齐对于可读性非常有帮助,所以试试这个:std::cout或者这个:std::cout(我更喜欢第一个,因为我发现在我的文本编辑器中格式化更容易)。

c++ - boost::thread 和 std::thread 之间的区别

我有一个使用boost::thread的地方(例如使用boost::asio)std::vector>threads;for(std::size_ti=0;ithread(newboost::thread(boost::bind(&boost::asio::io_service::run,io_services_[i])));threads.push_back(thread);}如果我尝试将它与std:thread一起使用,我会得到编译错误:std::vectorthreads;for(std::size_ti=0;iioServices.size();++i){std::thread

c++ - 嵌套的 std::function

有可能有一个std::function吗?返回std::function并使用与其他std::functions递归的各种函数,比如函数的函数?换句话说,我想将一组函数折叠成一个函数。例如脱离基础教程doublegenFunc(doublex,std::functionf){doubleres=f(x);returnres;}doublesquare(doublex){returnx*x;}doubledbl_sq(doublex){returnsquare(x*x);}我如何修改它以允许嵌套std::function电话? 最佳答案

C++ 将 memcpy 转换为 std::copy

我想用“std::copy”替换我的“memcpy”,但我找不到传递参数的正确方法。我的旧memcpy代码是memcpy(&uFeatures.Features[0],&((char*)(m_pData))[iBytePos],iByteCount);我用std::copy尝试了各种方法,但都没有用。有人能帮忙吗? 最佳答案 从你的语法来看,它似乎是这样的。(假设Features[0]是char*,如果不是你需要转换(检查评论))std::copy(&uFeatures.Features[0],&uFeatures.Features

分配大型静态std :: unordered_map导致堆栈溢出

我正在创建一个静态std::unordered_map如下:auto*__epsgMap__=newstd::unordered_map({{3819,CRS::Info("HD1909","+proj=longlat+ellps=bessel+towgs84=595.48,121.69,515.35,4.115,-2.9383,0.853,-3.408+no_defs")},{3821,CRS::Info("TWD67","+proj=longlat+ellps=aust_SA+no_defs")},{3824,CRS::Info("TWD97","+proj=longlat+ellps=G

c++ - std::atomic_compare_exchange_* 等如何与任意指针一起使用?

InterlockedCompareExchange在Windows中,以及__sync_val_compare_and_swap在gcc中采用指针,因此我可以传入任何地址,例如指向这些函数的共享内存块。对于非x86架构,我可能必须确保内存对齐以确保正确性,对于x86(可能还有其他),我可能希望确保缓存行对齐以提高性能,尽管正确性应该不是问题(->x86LOCK前缀)。为了摆脱我的代码中一些平台相关的东西(WindowsVC++与GCC),我查看了C++11的atomic_compare_exchange_weak。和friend。但它们都对std::atomic*类型的变量起作用.有

c++ - 如何编写接受 std::vector 或 std::list 的函数?

我想这个问题有点简单。vector和列表都有push和pop函数,而且-更重要的是-可以迭代:for(autovalue:items)...然而,std::vector和std::list似乎并不共享一个基类。因此,问题是:我如何编写一个函数来接受其中一个(或者,实际上,任何其他适合实现的东西)?std::lista;std::vectorb;DoSomething(a);DoSomething(b);我想在不重载的情况下进行。如果使用模板,它们不应该导致疯狂的错误消息。比如下面的代码——inta;DoSomething(a);--应该会导致调用站点出现编译错误,不在模板内的某处!有人

c++ - std::shuffle 的使用和效用?

如果您查看C++11中随机洗牌的规范,会发现有3个函数。我的问题是什么是典型的用途和优势:templatevoidshuffle(RandomItfirst,RandomItlast,URNG&&g);相比于:templatevoidrandom_shuffle(RandomItfirst,RandomItlast);我的意思是,似乎无论URNG是什么(均匀分布),结果都是相同的(从统计的角度来看)。我看到的唯一一点是std::shuffle是广告安全的,而std::random_shuffle的重载不是。你能确认一下吗?编辑:我认为URNG应该是一个统一的发行版,但它似乎无法编译。那