- Tumbleweed 2024.07.05-1.3
 - Leap-16.0
 - Leap-15.6
 
| std::tuple(3) | C++ Standard Libary | std::tuple(3) | 
NAME¶
std::tuple - std::tuple
Synopsis¶
 Defined in header <tuple>
  
   template< class... Types > (since C++11)
  
   class tuple;
  
   Class template std::tuple is a fixed-size collection of heterogeneous values.
    It is
  
   a generalization of std::pair.
  
   If std::is_trivially_destructible<Ti>::value is true for every Ti in
    Types, the
  
   destructor of std::tuple is trivial.
  
   If a program declares an explicit or partial specialization of std::tuple,
    the
  
   program is ill-formed, no diagnostic required.
Template parameters¶
Types... - the types of the elements that the tuple stores. Empty list is supported.
Member functions¶
 constructor constructs a new tuple
  
   (public member function)
  
   operator= assigns the contents of one tuple to another
  
   (public member function)
  
   swap swaps the contents of two tuples
  
   (public member function)
Non-member functions¶
 make_tuple creates a tuple object of the type defined by the
    argument
  
   (C++11) types
  
   (function template)
  
   tie creates a tuple of lvalue references or unpacks a tuple into
  
   (C++11) individual objects
  
   (function template)
  
   forward_as_tuple creates a tuple of forwarding references
  
   (C++11) (function template)
  
   tuple_cat creates a tuple by concatenating any number of tuples
  
   (C++11) (function template)
  
   get(std::tuple) tuple accesses specified element
  
   (C++11) (function template)
  
   operator==
  
   operator!=
  
   operator<
  
   operator<=
  
   operator>
  
   operator>= lexicographically compares the values in the tuple
  
   operator<=> (function template)
  
   (removed in C++20)
  
   (removed in C++20)
  
   (removed in C++20)
  
   (removed in C++20)
  
   (removed in C++20)
  
   (C++20)
  
   std::swap(std::tuple) specializes the std::swap algorithm
  
   (C++11) (function template)
  
   Helper concepts
  
   tuple-like specifies that a type implemented the tuple protocol
  
   pair-like (std::get, std::tuple_element, std::tuple_size)
  
   (C++23) (exposition-only concept*)
Helper classes¶
 std::tuple_size<std::tuple> obtains the size of tuple at
    compile time
  
   (C++11) (class template specialization)
  
   std::tuple_element<std::tuple> obtains the type of the specified
    element
  
   (C++11) (class template specialization)
  
   std::uses_allocator<std::tuple> specializes the std::uses_allocator
    type
  
   (C++11) trait
  
   (class template specialization)
  
   std::basic_common_reference<tuple-like> determines the common reference
    type of a
  
   (C++23) tuple and a tuple-like type
  
   (class template specialization)
  
   std::common_type<tuple-like> determines the common type of a tuple and
    a
  
   (C++23) tuple-like type
  
   (class template specialization)
  
   std::formatter<std::tuple> formatting support for tuple
  
   (C++23) (class template specialization)
  
   ignore placeholder to skip an element when
  
   (C++11) unpacking a tuple using tie
  
   (constant)
  
   Deduction guides (since C++17)
Notes¶
 Since the "shape" of a tuple – its size, the
    types of its elements, and the ordering
  
   of those types – are part of its type signature, they must all be
    available at
  
   compile time and can only depend on other compile-time information. This
    means that
  
   many conditional operations on tuples – in particular, conditional
    prepend/append
  
   and filter – are only possible if the conditions can be evaluated at
    compile time.
  
   For example, given a std::tuple<int, double, int>, it is possible to
    filter on types
  
   – e.g. returning a std::tuple<int, int> – but not to
    filter on whether or not each
  
   element is positive (which would have a different type signature depending on
  
   runtime values of the tuple), unless all the elements were themselves
    constexpr.
  
   As a workaround, one can work with tuples of std::optional, but there is
    still no
  
   way to adjust the size based on runtime information.
  
   Until N4387 (applied as a defect report for C++11), a function could not
    return a
  
   tuple using copy-list-initialization:
  
   std::tuple<int, int> foo_tuple()
  
   {
  
   return {1, -1}; // Error until N4387
  
   return std::tuple<int, int>{1, -1}; // Always works
  
   return std::make_tuple(1, -1); // Always works
  
   }
Example¶
// Run this code
  
   #include <iostream>
  
   #include <stdexcept>
  
   #include <string>
  
   #include <tuple>
  
   std::tuple<double, char, std::string> get_student(int id)
  
   {
  
   switch (id)
  
   {
  
   case 0: return {3.8, 'A', "Lisa Simpson"};
  
   case 1: return {2.9, 'C', "Milhouse Van Houten"};
  
   case 2: return {1.7, 'D', "Ralph Wiggum"};
  
   case 3: return {0.6, 'F', "Bart Simpson"};
  
   }
  
   throw std::invalid_argument("id");
  
   }
  
   int main()
  
   {
  
   const auto student0 = get_student(0);
  
   std::cout << "ID: 0, "
  
   << "GPA: " << std::get<0>(student0) <<
    ", "
  
   << "grade: " << std::get<1>(student0) <<
    ", "
  
   << "name: " << std::get<2>(student0) <<
    '\n';
  
   const auto student1 = get_student(1);
  
   std::cout << "ID: 1, "
  
   << "GPA: " << std::get<double>(student1) <<
    ", "
  
   << "grade: " << std::get<char>(student1) <<
    ", "
  
   << "name: " << std::get<std::string>(student1)
    << '\n';
  
   double gpa2;
  
   char grade2;
  
   std::string name2;
  
   std::tie(gpa2, grade2, name2) = get_student(2);
  
   std::cout << "ID: 2, "
  
   << "GPA: " << gpa2 << ", "
  
   << "grade: " << grade2 << ", "
  
   << "name: " << name2 << '\n';
  
   // C++17 structured binding:
  
   const auto [gpa3, grade3, name3] = get_student(3);
  
   std::cout << "ID: 3, "
  
   << "GPA: " << gpa3 << ", "
  
   << "grade: " << grade3 << ", "
  
   << "name: " << name3 << '\n';
  
   }
Output:¶
 ID: 0, GPA: 3.8, grade: A, name: Lisa Simpson
  
   ID: 1, GPA: 2.9, grade: C, name: Milhouse Van Houten
  
   ID: 2, GPA: 1.7, grade: D, name: Ralph Wiggum
  
   ID: 3, GPA: 0.6, grade: F, name: Bart Simpson
  
   Defect reports
  
   The following behavior-changing defect reports were applied retroactively to
  
   previously published C++ standards.
  
   DR Applied to Behavior as published Correct behavior
  
   LWG 2796 C++11 triviality of the destructor of specified
  
   std::tuple was unspecified
  
   the program is ill-formed
  
   LWG 3990 C++11 a program could declare an explicit or in this
  
   partial specialization of std::tuple case (no diagnostic
  
   required)
References¶
* C++23 standard (ISO/IEC 14882:2023):
  
   * 22.4 Tuples [tuple]
  
   * C++20 standard (ISO/IEC 14882:2020):
  
   * 20.5 Tuples [tuple]
  
   * C++17 standard (ISO/IEC 14882:2017):
  
   * 23.5 Tuples [tuple]
  
   * C++14 standard (ISO/IEC 14882:2014):
  
   * 20.4 Tuples [tuple]
  
   * C++11 standard (ISO/IEC 14882:2011):
  
   * 20.4 Tuples [tuple]
See also¶
 pair implements binary tuple, i.e. a pair of values
  
   (class template)
| 2024.06.10 | http://cppreference.com |