草庐IT

std-ranges

全部标签

c++ - std::chrono::steady_clock::now 如何报告错误?

这与mypreviousquestion有关我问std::chrono::steady_clock::now是否应该是noexcept。现在我知道了,我应该想知道这个函数是如何报告错误的吗?例如,此功能在Linux上的常见实现使用clock_gettime可以返回错误。 最佳答案 Linuxclock_gettime工具可能报告的所有错误在std::chrono::steady_clock::now()的调试实现中是不可能的.错误是:intclock_gettime(clockid_tclk_id,structtimespec*tp

c++ - 通过 std::unique_ptr 扩展变量的生命周期

使用C++11unique_ptr,对象的生命周期似乎被延长到其通常范围之外,如下面(相当人为的)示例所示:#include#includeusingnamespacestd;intmain(){unique_ptruPtr(nullptr);{charc='X';cout输出:c=Xc=Y通常在作用域结束时释放的字符c一直存在到程序结束。第二个输出是“Y”,表明unique_ptr不只是简单地复制它的值。是否建议以某种方式延长变量的生命周期?这是否安全,或者它是否具有与引用相同的危险? 最佳答案 WiththeC++11uniqu

c++ - 为什么 std::next 不接受 InputIterator?

ISOC++1124.3:templatevoidadvance(InputIterator&i,Distancen);//...templateForwardIteratornext(ForwardIteratorx,typenamestd::iterator_traits::difference_typen=1);为什么std::next不接受InputIterator?我正在考虑的合法用例之一是:first=find(next(first,x),last,11);//...我找到合适的DR:next/prevreturnanincrementediteratorwithoutch

c++ - 由于在 32 位的 G++ 4.4.7 20120313 中使用 C++ std::vector 中的内联函数导致精度发生变化

我正在centos5.932位(在64位机器上运行)上编译,目标是32位。g++版本为4.4.7,这不是centos5.9上默认提供的版本,但可以使用yum下载并作为发行版的一部分提供。我有一个非常简单的循环如下std::vectorresult(n);std::vectorvalues(n);//hereIcomputevalues().TheyarecorrectandIextensivelynoted//thatthere'snothingwrongthere.Theproblemishereresult[0]=0.0;for(inti=0;i在此代码的更复杂版本中(它显示了完全

c++ - std::static_pointer_cast 是否有任何额外的运行时开销?

相对于static_cast,即。所以,如果我们有这两个类型转换Base*b(newDerived());Derived*d=static_cast(b);//(1)shared_ptrb(newDerived());shared_ptrd=static_pointer_cast(b);//(2)第(2)行会比第(1)行慢吗? 最佳答案 是的,它有更多的开销,因为它必须返回一个新的shared_ptr而不是一个新的原始指针。boost实现是:templateshared_ptrstatic_pointer_cast(shared_p

c++ - 查找 std::vector 中每个唯一值的频率的有效方法

给定一个vectorstd::vectorv,我们可以通过以下方式有效地找到独特的元素:std::vectoruv(v.begin(),v.end());std::sort(uv.begin(),uv.end());std::erase(std::unique(uv.begin,uv.end()),uv.end());创建vector的最佳方式是什么(没有循环,使用STL或lambda):std::vectorfreq_uv(uv.size());其中将包含出现在v中的每个不同元素的频率(顺序与排序的唯一值相同)?注意:类型可以是任何东西,而不仅仅是double

C++: "reset"std::next_permutation()

有没有办法“重置”std::next_permutation()?假设我想多次检查vector的排列。我唯一能找到的是交替地通过next_permutation和prev_permutation。谢谢 最佳答案 “重置”将对序列进行排序,例如使用std::sort.请注意,如果您想使用next_permutation枚举所有排列,您必须从排序序列开始。此外,std::next_permutation一旦再次达到字典序最小排列,将返回false。 关于C++:"reset"std::nex

c++ - 为什么我们应该将 `std::unique_lock` 放在本地范围内?

基于C++EquivalenttoJava'sBlockingQueuevoidpush(Tconst&value){//originalversion{std::unique_locklock(this->d_mutex);d_queue.push_front(value);}this->d_condition.notify_one();}voidpush(Tconst&value){//myquestion//{//commentoutthescopestd::unique_locklock(this->d_mutex);d_queue.push_front(value);//}/

c++ - std::atomic 库依赖项 (gcc 4.7.3)

我一直在尝试使用std::atomic进行编译,但我得到了对__atomic_load、__atomic_store和__atomic_store_16的未解析引用。我知道在更高版本的gcc(4.8+?)中包含-latomic,但我正在使用gcc4.7.3进行编译;我试过添加-latomic_ops和-latomic_ops_gpl,但两者似乎都没有太大作用。我现在正在安装gcc4.8.1,但我确实有一个真正需要为4.7.3编译的发布平台。非常感谢。编辑:好的,这是导致我遇到的问题的一些代码:atomics.cpp#include#includestructdataStruct{int

c++ - 完美转发和 std::tuple

考虑以下代码:#include#include#include//A.templatevoidf(constchar*msg,Args&&...args){std::coutvoidf(constchar*msg,std::tuple&&t){std::coutg()const{returnstd::make_tuple(2,4,12345);}};intmain(){f("First",2,5,12345);f("Second",std::make_tuple(2,5,12345));boothe_boo;f("Third",the_boo.g());f("Fourth",std::