Zoeken…


Opmerkingen

Vouwuitdrukkingen worden ondersteund voor de volgende operatoren

+ - * / % \ & | << >>
+ = - = * = / = % = \ = & = | = << = >> = =
== ! = < > <= > = && || , . * -> *

Wanneer u over een lege reeks vouwt, is een vouwexpressie slecht gevormd, behalve voor de volgende drie operatoren:

operator Waarde wanneer het parameterpakket leeg is
&& waar
|| vals
, void ()

Unary Folds

Unaire vouwen worden gebruikt om parameterpakketten over een specifieke operator te vouwen . Er zijn 2 soorten unaire plooien:

  • Unary Left Fold (... op pack) die als volgt uitzet:

    ((Pack1 op Pack2) op ...) op PackN
    
  • Unary Right Fold (pack op ...) die zich als volgt uitbreidt:

    Pack1 op (... (Pack(N-1) op PackN)) 
    

Hier is een voorbeeld

template<typename... Ts>
int sum(Ts... args)
{
    return (... + args); //Unary left fold
    //return (args + ...); //Unary right fold

    // The two are equivalent if the operator is associative.
    // For +, ((1+2)+3) (left fold) == (1+(2+3)) (right fold)
    // For -, ((1-2)-3) (left fold) != (1-(2-3)) (right fold)
}

int result = sum(1, 2, 3); //  6

Binaire plooien

Binaire plooien zijn in feite unaire plooien , met een extra argument.

Er zijn 2 soorten binaire plooien:

  • Binaire linker vouw - (value op ... op pack) - breidt zich als volgt uit:

    (((Value op Pack1) op Pack2) op ...) op PackN
    
  • Binaire juiste vouw (pack op ... op value) - breidt zich als volgt uit:

    Pack1 op (... op (Pack(N-1) op (PackN op Value)))
    

Hier is een voorbeeld:

template<typename... Ts>
int removeFrom(int num, Ts... args)
{
    return (num - ... - args); //Binary left fold
    // Note that a binary right fold cannot be used
    // due to the lack of associativity of operator-
}

int result = removeFrom(1000, 5, 10, 15); //'result' is 1000 - 5 - 10 - 15 = 970

Een komma omvouwen

Het is een gebruikelijke bewerking om voor elk element in een parameterpakket een bepaalde functie uit te voeren. Met C ++ 11 is het beste wat we kunnen doen:

template <class... Ts>
void print_all(std::ostream& os, Ts const&... args) {
    using expander = int[];
    (void)expander{0,
        (void(os << args), 0)...
    };
}

Maar met een vouwuitdrukking vereenvoudigt het bovenstaande mooi om:

template <class... Ts>
void print_all(std::ostream& os, Ts const&... args) {
    (void(os << args), ...);
}

Geen cryptische boilerplate vereist.



Modified text is an extract of the original Stack Overflow Documentation
Licentie onder CC BY-SA 3.0
Niet aangesloten bij Stack Overflow