草庐IT

readable_date_ranges

全部标签

c++ - 在抛出 'std::out_of_range' 实例后调用终止

为什么会发生这种情况我的程序说它没有错误但是当我运行它时我在抛出'std::out_of_range'what():vector:_M_range_check实例后被调用终止。我是c++的新手,所以我不明白这些错误#include#include#include#includeusingnamespacestd;usingstd::vector;intmain(){vectordeck;vectornums;default_random_engineeng(time(0));uniform_int_distributiondis(0,51);intpos1;intpos2;intnum

c++ - 错误 : Range-based 'for' loops are not allowed in C++98 mode

所以我正在关注此页面上的教程:http://www.cplusplus.com/doc/tutorial/control/但是我在做范围/基于for循环时遇到了麻烦。我找到了这个页面:GNUGCCcompilerupdating那里的答案说我应该打开“项目”和“属性”。但是当我尝试这样做时,“属性”选项变灰了,没有任何解释:http://imageshack.com/a/img571/4371/xd1x.png那么..我怎样才能激活范围/基于for循环? 最佳答案 将-std=c++11标志传递给编译器。当然,GCC应该足够新(>=

c++ - C++17 中新的基于范围的 for 循环如何帮助 Ranges TS?

委员会将基于范围的for循环从:C++11:{auto&&__range=range_expression;for(auto__begin=begin_expr,__end=end_expr;__begin!=__end;++__begin){range_declaration=*__begin;loop_statement}}C++17:{auto&&__range=range_expression;auto__begin=begin_expr;auto__end=end_expr;for(;__begin!=__end;++__begin){range_declaration=*_

c++ - 在并行算法中使用 ranges::view::iota

由于没有基于索引的parallelforalgorithm在c++17,我想知道ranges::view::iota可以与std::for_each结合使用模仿那个。即:usingnamespacestd;constexprintN=10'000'000;ranges::iota_viewindices(0,N);vectorv(N);for_each(execution::par_unseq,indices.begin(),indices.end(),[&](inti){v[i]=i;});iota_view似乎为适当的类型提供随机访问([range.iota.iterator]):

C++ : convert date/time string to tm struct

将此视为对thisquestion的跟进.从本质上讲,C++日期/时间格式化工具似乎无可救药地被破坏了——以至于为了做一些像将日期/时间字符串转换为对象这样简单的事情,你真的不得不求助于Boost.Datetime或旧的Cstrftime/strptime工具。问题是这些解决方案都不能直接与特定iostream对象上的C++区域设置一起工作。C工具使用全局C/POSIX语言环境设置,而Boost.Datetime中的I/O工具似乎完全绕过iostream语言环境设置,允许用户直接设置月份、工作日等的名称,而不管语言环境如何。因此,我想要一些能够尊重注入(inject)特定I/O流的语言

c++ - boost::date_time (boost-145) 使用带有微秒计算的 64 位 uint,没有截断

我正在使用date_time来抽象掉平台特性。我需要生成一个64位微秒分辨率uint64_t,它将用于序列化。我不明白下面出了什么问题。#include#include#includeusingnamespaceboost::posix_time;usingboost::uint64_t;ptimeUNIX_EPOCH(boost::gregorian::date(1970,1,1));intmain(){ptimecurrent_time=microsec_clock::universal_time();std::cout这是我得到的输出。originaltime:2010-Dec-

C++0x : Range overloads for standard algorithms?

std::sort(range(c));相对于std::sort(c.begin(),c.end();您是否期望下一个标准为标准算法提供范围重载?Boost的rangeiterators是类似的东西,TC++PL3e中提到的BjarneStroustrup的iseq()也是同样的思路。我看过thelatestdraftIcouldfind但没有看到提到范围过载。 最佳答案 History页面提供了部分答案。必须迫切需要向std命名空间添加重载。请注意,这是图书馆问题。您可以搜索文件,看看以前是否有人提出过将这些添加到图书馆的请求。如

c++ - 如何将 __DATE__ 和 __TIME__ 宏拆分为变量声明的单独组件?

我有以下结构(在嵌入式系统上):structCalib_Time_struct{uint16_tyear;uint16_tmonth;uint16_tday;uint16_thour;uint16_tminute;uint16_tseconds;};我有一个“默认”值数组,我需要在其中插入时间值:structCalib_Table_struct{unsignedinttable_id;//!我想从__DATE__宏中填写“modification_date”成员的年、月和日。有没有办法做到这一点?(有什么技巧吗?)是否可以将类似的方法或hack应用于__TIME__宏?动机是允许编译器

c++ - VC++2008项目总是 "out of date"

在一个解决方案中,我有两个VC++项目。项目A的链接器输入是由项目B编译的.obj文件。VisualStudio(2008)总是告诉我项目A“已过时”,并在每次我想运行/调试/构建时提示我询问是否要重建它/ETC。即使在构建整个解决方案后立即:我做了一个成功的完整构建,然后再次单击构建,它想要重新链接项目A。如何防止这种情况发生?有人知道这里发生了什么吗? 最佳答案 我认为解决方案是停止使用其他项目中的.obj文件。相反,将A和B项目通用的代码分解到自己的静态库C中,并将A和B链接到它。

c++ - 如何将 `boost::range` 迭代器与标准迭代器一起使用

我有接受std::vector迭代器的函数,如typedefstd::vectorPoints;PointsConvexHull(Points::const_iteratorfirst,Points::const_iteratorlast);我通常将std迭代器传递给它们,但偶尔我需要使用boost迭代器,例如boost::join's范围迭代器。我应该如何更改我的函数的参数化,最好没有模板,以便它们接受两个迭代器?此外,如何在每种类型中指出我需要哪些迭代器概念?我试着查看boost::range文档,但它让我非常困惑,我不知道从哪里开始。例如,我找不到boost::range_det