std:: data
      From cppreference.net
     
     
     | 
           定义于头文件
            
            
             <array>
            
            | ||
| 
           定义于头文件
            
            
             <deque>
            
            | ||
| 
           定义于头文件
            
            
             <flat_map>
            
            | ||
| 
           定义于头文件
            
            
             <flat_set>
            
            | ||
| 
           定义于头文件
            
            
             <forward_list>
            
            | ||
| 
           定义于头文件
            
            
             <inplace_vector>
            
            | ||
| 
           定义于头文件
            
            
             <iterator>
            
            | ||
| 
           定义于头文件
            
            
             <list>
            
            | ||
| 
           定义于头文件
            
            
             <map>
            
            | ||
| 
           定义于头文件
            
            
             <regex>
            
            | ||
| 
           定义于头文件
            
            
             <set>
            
            | ||
| 
           定义于头文件
            
            
             <span>
            
            | ||
| 
           定义于头文件
            
            
             <string>
            
            | ||
| 
           定义于头文件
            
            
             <string_view>
            
            | ||
| 
           定义于头文件
            
            
             <unordered_map>
            
            | ||
| 
           定义于头文件
            
            
             <unordered_set>
            
            | ||
| 
           定义于头文件
            
            
             <vector>
            
            | ||
| 
           
           
           
            
             template
            
            
             <
            
            
             class
            
            C
            
             >
            
             constexpr auto data ( C & c ) - > decltype ( c. data ( ) ) ; | (1) | (C++17 起) | 
| 
           
           
           
            
             template
            
            
             <
            
            
             class
            
            C
            
             >
            
             constexpr auto data ( const C & c ) - > decltype ( c. data ( ) ) ; | (2) | (C++17 起) | 
| 
           
           
           
            
             template
            
            
             <
            
            
             class
            
            T,
            
             
              std::
              
               size_t
              
             
            
            N
            
             >
            
             constexpr T * data ( T ( & array ) [ N ] ) noexcept ; | (3) | (C++17 起) | 
| 
           
           
           
            
             template
            
            
             <
            
            
             class
            
            E
            
             >
            
             constexpr const E * data ( std:: initializer_list < E > il ) noexcept ; | (4) | (C++17 起) | 
返回指向包含该范围元素的内存块的指针。
       
        1,2)
       
       返回
       
        
         c.
         
          data
         
         
          (
         
         
          )
         
        
       
       。
      
      
       
        3)
       
       返回
       
        
         array
        
       
       。
      
      
       
        4)
       
       返回
       
        
         il.
         
          begin
         
         
          (
         
         
          )
         
        
       
       。
      
      | 目录 | 
参数
| c | - | 具有 data ( ) 成员函数的容器或视图 | 
| array | - | 任意类型的数组 | 
| il | - | 一个 std::initializer_list | 
返回值
       
        1,2)
       
       
        
         c.
         
          data
         
         
          (
         
         
          )
         
        
       
      
      
       
        3)
       
       
        
         array
        
       
      
      
       
        4)
       
       
        
         il.
         
          begin
         
         
          (
         
         
          )
         
        
       
      
      异常
       
        1)
       
       可能抛出实现定义的异常。
      
      注释
       针对
       
        
         std::initializer_list
        
       
       的重载是必需的,因为它没有名为
       
        data
       
       的成员函数。
      
| 功能测试 宏 | 值 | 标准 | 功能 | 
|---|---|---|---|
| 
           __cpp_lib_nonmember_container_access
           | 
           201411L
           | (C++17) | std::size()
          
         
         , 
          std::data()
         , and
         
          
           std::empty() | 
可能的实现
| 第一版本 | 
|---|
| template<class C> constexpr auto data(C& c) -> decltype(c.data()) { return c.data(); } | 
| 第二版本 | 
| template<class C> constexpr auto data(const C& c) -> decltype(c.data()) { return c.data(); } | 
| 第三版本 | 
| template<class T, std::size_t N> constexpr T* data(T (&array)[N]) noexcept { return array; } | 
| 第四版本 | 
| template<class E> constexpr const E* data(std::initializer_list<E> il) noexcept { return il.begin(); } | 
示例
         运行此代码
        
       #include <cstring> #include <iostream> #include <string> int main() { std::string s{"Hello world!\n"}; char a[20]; // 用于存储C风格字符串的空间 std::strcpy(a, std::data(s)); // 自C++11起,[s.data(), s.data() + s.size()] 保证是一个空终止字节序列 std::cout << a; }
输出:
Hello world!
参见
| 
           
            
             
              (C++20)
             
            
           
           | 获取连续范围起始位置的指针 (定制点对象) | 
| 
           
            
             
              (C++20)
             
            
           
           | 获取只读连续范围起始位置的指针 (定制点对象) |