草庐IT

std-ranges

全部标签

c++ - 错误 : ‘template<class> class std::auto_ptr’ is deprecated

我正在使用scons和ubuntu。当我使用'scons'制作一些程序时,会发生错误,例如,src/db/DBTextLoader.cc:296:3:error:‘templateclassstd::auto_ptr’isdeprecated[-Werror=deprecated-declarations]/usr/include/c++/5/bits/unique_ptr.h:49:28:note:declaredheretemplateclassauto_ptr;这是我的命令;$./configuer$sourcesomething.sh$scons其实我也不知道。我已经在搜索这个

C++ catch(std::exception & e) 与 catch(...)

我知道处理这两个捕获的不同之处,但是椭圆捕获std::exceptioncatch无法捕获的东西需要什么?例如:try{throwstd::runtime("runtimeerror!");}catch(conststd::exception&e){std::cout我看过结合使用这两种方法的代码示例,但我没有看到您同时使用这两种方法的原因。 最佳答案 catch(conststd::exception&e)只会捕获标准异常。catch(...)之后会捕获那里的所有内容。您可以处理整数和其他类型(http://www.cpluspl

c++ - 制作 std::vector capacity>=N 和 size=0 的最佳方法?

给定一个std::vector,其大小和容量可以是任意的,将其大小更改为0并将容量更改为至少N(给定数字)的最佳做法是什么?我的直接想法是:voidf(vector&t,intN){t.clear();t.reserve(N);}但是我注意到了Areallocationisnotguaranteedtohappen,andthevectorcapacityisnotguaranteedtochange(whenstd::vector::cleariscalled).所以我想知道当原始容量大于给定的N时如何避免重新分配? 最佳答案 w

c++17 通过生成预先声明的类型列表的笛卡尔积来制作 std::variant

假设我有一个包含三个模板类型参数的类。templatestructConfiguredPipeline{};并且有以下类稍后在实例化ConfiguredPipeline时使用:templatestructCriteriaList{};usingSupportedCriteria=CriteriaList;templatestructStrategiesList{};usingSupportedStrategies=StrategiesList;templatestructTransformerList{};usingSupportedTransformer=TransformerLis

c++ - 将带有 unique_ptr 的可变 lambda 传递给 const& std::function

我有一个调度函数,它在主线程中执行给定的lambda。为了这个问题,假设它看起来像下面这样:voiddispatch(conststd::function&fn){fn();}我需要在不中断主线程的情况下在新线程中加载新对象。所以我执行以下操作:1)启动一个新线程并在线程内创建一个新的唯一指针,2)调用dispatch并将新的唯一指针传播到它所属的位置。std::unique_ptrfoo;//nullptr//dotheloadinginanewthread:std::threadt([&](){//inthenewthread,loadnewvalue"Blah"andstorei

c++ - 用于取消标志的 std::atomic_bool:std::memory_order_relaxed 是正确的内存顺序吗?

我有一个从套接字读取并生成数据的线程。每次操作后,线程都会检查一个std::atomic_bool标志以确定它是否必须提前退出。为了取消操作,我将取消标志设置为true,然后在工作线程对象上调用join()。线程和取消函数的代码如下所示:std::threadwork_thread;std::atomic_boolcancel_requested{false};voidthread_func(){while(!cancel_requested.load(std::memory_order_relaxed))process_next_element();}voidcancel(){can

c++ - 如何创建包含 std::atomic 的 std::pair?

我不知道如何创建以下内容:std::pair,int>我总是得到/usr/include/c++/5.5.0/bits/stl_pair.h:139:45:error:useofdeletedfunction'std::atomic::atomic(conststd::atomic&)':first(__x),second(std::forward(__y)){}我试过了std::pair,int>pair=std::make_pair(true,1);//doesn'tworkstd::pair,int>pair=std::make_pair({true},1);//doesn'tw

c++ - 使用 std::transform 制作一对 vector

我想从一对vector开始创建一个vector对。例如,如果A是std::vectorA=[101]并且B是std::vectorB=[010],我想要一个结构std::vectorC=[10,01,10]其中C_i=std::pair(A_i,B_i).我会避免for循环遍历两个vector,所以我正在寻找像std::transform()这样的几行代码。我尝试了以下代码:std::vectorboolPredLabel(tsLabels.size());std::vectorboolRealLabel(tsLabels.size());std::vector>TrPrPair(ts

c++ - 什么时候调用 std::thread 析构函数?

我知道std::thread析构函数在主退出时调用,或者当线程对象超出范围时调用。但是当它调用的函数执行完毕时它是否也被销毁了?如果不是这样的线程会发生什么,我还能join()它吗? 最佳答案 Butisitalsodestroyedwhenafunctionthatitiscallingisdoneexecuting?Ifnotwhathappenstosuchathread,canIstilljoin()it?不,它没有被销毁,但标记为joinable().所以是的,您仍然可以join()它。否则从你的问题的标题(“什么时候调用

c++ - 为什么 std::istream 不承担其 streambuf 的所有权?

我正在为视频游戏编写某种虚拟文件系统库,例如CRI中间件的ROFS(参见Wikipedia)。我对库的意图是提供访问我开发的游戏资源的自然方式,这些资源存储一些嵌入在可执行文件中的数据,一些在媒体上,一些在本地用户的硬盘驱动器上(首选项,保存游戏文件等).访问这些资源应该像调用一样简单std::auto_ptrdefaultConfigIStream(fslib.inputStream("self://defaultConfig.ini"));std::auto_ptrdefaultConfigOStream(fslib.outputStream("localappdata://con