草庐IT

device_view

全部标签

c++ - map 、集合等的 array_view 替代方案

假设我有一些类层次结构,其中有几个virtual返回容器引用的函数:#include#include#include#include#includeclassInterface{public:virtualconststd::vector&getArray()const=0;virtualconststd::set&getSet()const=0;virtualconststd::map&getMap()const=0;};classSubclassA:publicInterface{public:conststd::vector&getArray()constoverride{ret

c++ - nVidia 推力 : device_ptr Const-Correctness

在我广泛使用nVidiaCUDA的项目中,我有时会使用Thrust来做它做得非常非常好的事情。Reduce是一种在该库中实现得特别好的算法,reduce的一个用途是通过将每个元素除以所有元素的总和来规范化非负元素的vector元素。templatevoidnormalise(Tconst*constd_input,constunsignedintsize,T*d_output){constthrust::device_ptrX=thrust::device_pointer_cast(const_cast(d_input));Tsum=thrust::reduce(X,X+size);t

range-v3 partial_sum View 的 C++ 意外值类型

考虑以下最小示例:#include#includenamespacerng=ranges::v3;intmain(){std::vectorv{6,2,3,4,5,6};autof=[](autoa,autob){returna*0.3+b*0.7;};autorng=v|rng::view::partial_sum(f);for(autoi:rng){std::cout这输出632345我本以为会在这里看到双数,但结果显然是整数。这与view::transform的行为相反。这样做的原因是因为在实现中,running-sum值具有与源范围对应的类型:semiregular_t>sum

c++ - "QIODevice::write: device not open"文件打开时

当我编译我的程序时,我收到错误消息“QIODevice::write:devicenotopen”这个程序在我的旧电脑上运行但由于某种原因它在我的新电脑上不运行。非常感谢任何有关如何修复此错误的见解,谢谢。file.open(QIODevice::Append);file2.open(QIODevice::Append);QTextStreamstream(&file);//streamofinformationQTextStreamstream2(&file2);//writetofile//codecontinuedhere,deletedtoposthere...stream

c++ - 如何使用 range-v3 库从 std::vector 获取列 View 和行 View ?

将7x5矩阵展平为std::vector,我想使用EricNiebler的range-v3库查看列和行。到目前为止,我设法(有改进的余地)获得单行、单列和连接行的View。参见:https://wandbox.org/permlink/8o4RgSucF3zSNuPNstd::vectornumbers={00,01,02,03,04,10,11,12,13,14,20,21,22,23,24,30,31,32,33,34,40,41,42,43,44,50,51,52,53,54,60,61,62,63,64,};constsize_tn=5;//numberofcolumns//R

c++ - C++20 范围的切片 View

Python的itertools具有islice(seq,start,stop,step)过程,它接受一个序列并返回每个step的迭代器start和stop之间序列值的第th个值。C++20的Ranges库是否提供类似的功能,例如像slice这样的函数,它采用随机访问迭代器start、标记stop和步长值step,并返回一个随机访问迭代器,该迭代器迭代start和stop之间的每个stepth值?如果没有,是否可以使用Ranges库提供的原语来实现这样的迭代器适配器?(我知道如何手动实现这样的适配器,所以这不是问题。) 最佳答案 不

c++ - Boost.Hana 中是否有与 Boost.Fusion 中的 View 概念等效的概念?

我尝试使用hana::for_each迭代用户定义的结构,并注意到它被复制/移动,而Boost.Fusion允许您迭代在原始结构上。我没有在Boost.Hana中找到任何类似于Boost.Fusion的View概念。如何将转换应用于序列而不每次都复制/移动它们?#include#includestructFoo{Foo()=default;Foo(constFoo&){std::cout更新:我尝试使用hana::transform将std::ref应用于成员,但是Struct不是Functior,所以transform不适用于这种情况。我能够使用hana::accessors实现所需

c++ - 如何在 constexpr string_view 上使用 std::string_view::remove_prefix()

std::string_view::remove_prefix()和std::string_view::remove_suffix()都是c中的constexpr成员函数++17;但是,它们会修改调用它们的变量。如果值是constexpr,它也将是const并且不能修改,那么这些函数如何用于constexpr值?换句话说:constexprstd::string_viewa="asdf";a.remove_prefix(2);//compileerror-aisconst如何在constexprstd::string_view上使用这些函数?如果它们不能在constexprstd::s

c++ - 为什么没有类似于 std::string_view 的 view<T>

我知道std::string_view是对字符串的非拥有引用和std::string_view之间的主要区别和std::string是现在,为什么std::string_view不适用于其他类型?或者为什么这个实现只针对std::string?例如:如果我们有类似的generic_view其中T可以是任何类型,包括自定义类型。有了这个,而不是使用constT&作为函数参数,generic_view可以使用。以及std::string_view的其他优势将很有用,如分配、复制等。 最佳答案 C++20中有一个非拥有类型,用于任意对象的

c++ - std::string_view 编译时散列

似乎std::hashfunctions对于C++17string_view不是constexpr的。在我看来,绑定(bind)到constchar[]的字符串View可以在编译时进行哈希处理(这会非常好),或者有什么可以阻止这种情况吗? 最佳答案 从C++14开始(参见17.6.3.4哈希要求,表26),我们有:Thevaluereturnedshalldependonlyontheargumentkforthedurationoftheprogram.[Note:Thusallevaluationsoftheexpression