草庐IT

std-ranges

全部标签

c++ - static_cast<T&&>(t) 编译速度比 std::forward<T>(t) 快?

最近,我在这里阅读了range-v3的提交评论:https://github.com/ericniebler/range-v3/commit/a4829172c0d6c43687ba213c54f430202efd7497提交消息说,marginallyimprovecompiletimesbyreplacingstd::forwardwithstatic_cast我知道std::forward(t)返回static_cast(t),按照标准。我也知道有时static_cast(t)当T&&t时会正常工作是通过引用折叠规则的通用引用(或转发引用)。我感兴趣的是提交消息说static_c

c++ - std::vector 手动中毒

在下面的代码片段中,有一个错误不是微不足道的,但我希望像AddressSanitizer这样的工具能够捕捉到它。#include#includeintmain(){std::vectortoto;toto.push_back(2);intconst&titi=toto[0];toto.pop_back();std::cout当在vector范围内打印并在范围外打印catch引用时,会抛出use-heap-after-free错误。但是当没有作用域时,std::vector实现可能不会在pop_back之后释放内存,因此引用仍然指向有效内存。我四处搜索,发现您可以手动毒化内存,我想知道这

c++ - 为什么 std::scan_is 在 vi​​sual studio 编译器中发出运行时错误?

示例here在VisualStudio2013中发出内存访问冲突的运行时错误。#include#include#includeintmain(){auto&f=std::use_facet>(std::locale(""));//skipuntilthefirstletterchars1[]="\t\t\nTest";constchar*p1=f.scan_is(std::ctype_base::alpha,std::begin(s1),std::end(s1));std::cout这是为什么呢?编译器的错误实现? 最佳答案 aut

c++ - 为什么 std::forward 将左值和右值转换为右值引用?

我想我对std::forward感到困惑.我的函数使用std::forward如下,但为了便于解释,它进行了很多简化和修改。//Thisisanexamplecodetoexplainmyquestionsimply.templatevoidadd(Element&&element){staticstd::vectorvec;vec.push_back(std::forward(element));}我用上面的函数尝试了两种情况;Case1左值参数和Case2右值参数。案例1:左值参数autosome_class=SomeClass();add(some_class);案例2:右值参数

c++ - 如何获得 std::uniform_int_distribution 的实现不可知版本?

std::uniform_int_distribution接受任何>的PRNG,包括跨实现和平台一致的PRNG。然而,std::uniform_int_distribution本身似乎在实现之间并不一致,因此我不能指望能够复制它们,即使使用通用的PRNG和种子也是如此。这也会影响相关功能,例如std::shuffle().例如:#include#include#include#includetemplatevoidprintvector(conststd::string&title,conststd::vector&v){std::coutvPRNG;for(inti=0;ivUnif

c++ - 并行 STL 是否处理插入迭代器,例如 std::back_insert_iterator?

并行STL算法是否符合std::back_insert_iterator??我可能误解了std::par和std::par_vec之间的区别,std::par_vec是否意味着输出范围是否需要预先分配?代码示例:autonumbers={1,2,3,4,5,6};autosquared=std::vector{};std::transform(**std::par/std::par_vec,**numbers.begin(),numbers.end(),std::back_inserter(squared),[](autoval){returnval*val;});更新简化问题,因为我

c++ - c++ std_lib_facilities.h 还在用吗?

我正在通过BjarneStroustrup的《编程:原则与实践》学习C++。他们给出了一个示例程序://readandwriteafirstname#include"std_lib_facilities.h"intmain(){cout>first_name;//readcharactersintofirst_namecout当我在visualstudio中键入相同的代码时,头文件“std_lib_facilities.h”出现错误。我很困惑用这个头文件。还在用吗?除了这个header,我还可以使用什么? 最佳答案 在本书的附录(具

c++ - 使用 std::initializer_list 构造函数而不产生歧义?

我有一个类叫做Shape,它可以从任何可迭代对象和一个名为Array的类中初始化,其中只包含一个Shape.但是,当我尝试初始化Array时,我遇到了无法解释的编译错误。:classShape{public:templateShape(Iteratorfirst,Iteratorlast):m_shape(first,last){}templateShape(constIterable&shape):Shape(shape.begin(),shape.end()){}templateShape(std::initializer_listshape):Shape(shape.begin(

c++ - std::memcpy 或显式 char 值赋值 - 在 C++ 中相等且合法

在下面的示例中,uint32_t的值表示被复制到uint8_t数组。这是由std::memcpy完成的。据我了解C++标准,这是完全合法的:我们通过转换为unsignedchar*的T*访问类型为T的对象。没有别名问题,没有对齐问题。反之则不太明显。我们正在通过unsignedchar*访问T的对象表示,这是合法的。但是访问这个词包括改变吗?当然没有锯齿和对齐问题。然而,如果缓冲区s中的值来自外部来源,则会出现问题:我们必须确保正确的字节顺序并省略陷阱表示。可以检查正确的字节顺序,这样就可以解决。但是陷阱表示呢?我们怎样才能避免这种情况?或者uint类型没有陷阱表示而不是说double

c++ - 为什么没有 std::string_view 的模板构造函数?

我正在阅读documentationforstd::string_view,我注意到这些是构造函数:constexprbasic_string_view()noexcept;constexprbasic_string_view(constbasic_string_view&other)noexcept=default;constexprbasic_string_view(constCharT*s,size_typecount);constexprbasic_string_view(constCharT*s);他们为什么不介绍这个?templateconstexprbasic_strin