如何将STD::VECTOR转换为STD::SPAN?

2022-05-16 00:00:00 c++ c++20

在std::span constructors上的文档中,没有一个文档接受std::矢量。

那么,此代码(source page)是如何编译的?

// createSpan.cpp

#include <algorithm>
#include <iostream>
#include <span>
#include <vector>

int main() {

    std::cout << std::endl;
    std::cout << std::boolalpha;

    std::vector myVec{1, 2, 3, 4, 5};
    
    std::span mySpan1{myVec};                                        // (1)
    std::span mySpan2{myVec.data(), myVec.size()};                   // (2)
    
    bool spansEqual = std::equal(mySpan1.begin(), mySpan1.end(),
                                 mySpan2.begin(), mySpan2.end());
    
    std::cout << "mySpan1 == mySpan2: " << spansEqual << std::endl;  // (3)

    std::cout << std::endl;
    
}

即在(%1)处调用了std::span的哪个构造函数?


解决方案

它是重载集中的构造函数(7):

template< class R >
explicit(extent != std::dynamic_extent)
constexpr span( R&& r );

来自解释:

构造一个范围是范围r上的视图的范围;结果范围具有size() == std::ranges::size(r)data() == std::ranges::data(r)

对此签名何时参与重载解析有进一步的限制,但这是本质。和std::vector满足这些要求。

这是一件好事,因为它允许自定义(非<2-3]>)容器允许隐式转换为std::span实例。

相关文章