Namespaces
Variants

std:: as_bytes, std:: as_writable_bytes

From cppreference.net
Défini dans l'en-tête <span>
template < class T, std:: size_t N >

std:: span < const std:: byte , S /* voir ci-dessous */ >

as_bytes ( std:: span < T, N > s ) noexcept ;
(1) (depuis C++20)
template < class T, std:: size_t N >

std:: span < std:: byte , S /* voir ci-dessous */ >

as_writable_bytes ( std:: span < T, N > s ) noexcept ;
(2) (depuis C++20)

Obtient une vue de la représentation objet des éléments du span s .

Si N est std::dynamic_extent , l'étendue du span retourné S est également std::dynamic_extent ; sinon elle est sizeof ( T ) * N .

as_writable_bytes ne participe à la résolution de surcharge que si std:: is_const_v < T > est false .

Valeur de retour

1) Un span construit avec { reinterpret_cast < const std:: byte * > ( s. data ( ) ) , s. size_bytes ( ) } .
2) Un span construit avec { reinterpret_cast < std:: byte * > ( s. data ( ) ) , s. size_bytes ( ) } .

Exemple

#include <cstddef>
#include <iomanip>
#include <iostream>
#include <span>
void print(float const x, std::span<const std::byte> const bytes)
{
    std::cout << std::setprecision(6) << std::setw(8) << x << " = { "
              << std::hex << std::uppercase << std::setfill('0');
    for (auto const b : bytes)
        std::cout << std::setw(2) << std::to_integer<int>(b) << ' ';
    std::cout << std::dec << "}\n";
}
int main()
{
    /* mutable */ float data[1]{3.141592f};
    auto const const_bytes = std::as_bytes(std::span{data});
    print(data[0], const_bytes);
    auto const writable_bytes = std::as_writable_bytes(std::span{data});
    // Modifie le bit de signe qui est le MSB (Standard IEEE 754 pour les nombres à virgule flottante).
    writable_bytes[3] |= std::byte{0B1000'0000};
    print(data[0], const_bytes);
}

Sortie possible :

 3.14159 = { D8 0F 49 40 }
-3.14159 = { D8 0F 49 C0 }

Voir aussi

crée implicitement des objets dans un stockage donné avec la représentation d'objet réutilisée
(modèle de fonction)
(C++17)
le type byte
(énumération)