Namespaces
Variants

std::chrono:: operator<< (std::chrono::day)

From cppreference.net
< cpp ‎ | chrono ‎ | day
Défini dans l'en-tête <chrono>
template < class CharT, class Traits >

std:: basic_ostream < CharT, Traits > &

operator << ( std:: basic_ostream < CharT, Traits > & os, const std:: chrono :: day & d ) ;
(depuis C++20)

Forme une std:: basic_string < CharT > s constituée de la valeur du jour stockée dans d formatée en tant que nombre décimal, avec un zéro non significatif si le résultat serait autrement un chiffre décimal unique. Puis, si ! d. ok ( ) , ajoute " is not a valid day" à la chaîne formatée. Insère cette chaîne dans os .

Équivalent à

return os << ( d. ok ( ) ?
std:: format ( STATICALLY_WIDEN < CharT > ( "{:%d}" ) , d ) :
std:: format ( STATICALLY_WIDEN < CharT > ( "{:%d} n'est pas un jour valide" ) , d ) ) ;

STATICALLY_WIDEN < CharT > ( "..." ) est "..." si CharT est char , et L "..." si CharT est wchar_t .

Valeur de retour

os

Exemple

#include <chrono>
#include <iostream>
int main()
{
    constexpr std::chrono::day d1{31}, d2{7}, d3{42}, d4{};
    std::cout << d1 << '\n'
              << d2 << '\n'
              << d3 << '\n'
              << d4 << '\n';
}

Sortie possible :

31
07
42 is not a valid day
00 is not a valid day

Voir aussi

(C++20)
stocke la représentation formatée des arguments dans une nouvelle chaîne
(modèle de fonction)
prise en charge du formatage pour day
(spécialisation de modèle de classe)