Defined in header <tuple> | ||
|---|---|---|
template< class... Types > class tuple; | (since C++11) |
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 tuple is trivial.
| Types... | - | the types of the elements that the tuple stores. Empty list is supported. |
|
(C++11) | constructs a new tuple (public member function) |
|
(C++11) | assigns the contents of one tuple to another (public member function) |
|
(C++11) | swaps the contents of two tuples (public member function) |
|
(C++11) | creates a tuple object of the type defined by the argument types (function template) |
|
(C++11) | creates a tuple of lvalue references or unpacks a tuple into individual objects (function template) |
|
(C++11) | creates a tuple of forwarding references (function template) |
|
(C++11) | creates a tuple by concatenating any number of tuples (function template) |
|
(C++11) | tuple accesses specified element (function template) |
|
(removed in C++20)(removed in C++20)(removed in C++20)(removed in C++20)(removed in C++20)(C++20) | lexicographically compares the values in the tuple (function template) |
|
(C++11) | specializes the std::swap algorithm (function template) |
|
(C++23) | specifies that a type implemented the tuple protocol ( std::get, std::tuple_element, std::tuple_size) (exposition-only concept) |
|
(C++11) | obtains the size of tuple at compile time (class template specialization) |
|
(C++11) | obtains the type of the specified element (class template specialization) |
|
(C++11) | specializes the std::uses_allocator type trait (class template specialization) |
|
(C++23) | determines the common reference type of a tuple and a tuple-like type (class template specialization) |
|
(C++23) | determines the common type of a tuple and a tuple-like type (class template specialization) |
|
(C++11) | placeholder to skip an element when unpacking a tuple using tie (constant) |
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
}#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
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 tuple was unspecified | specified |
| implements binary tuple, i.e. a pair of values (class template) |
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
https://en.cppreference.com/w/cpp/utility/tuple