std::tuple (3) Linux Manual Page
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_v<Types> && …) is true, the destructor of tuple is trivial. (since C++17)
Template parameters
Types… – the types of the elements that the tuple stores. Empty list is supported.
Member functions
constructor (public member function)
operator= (public member function)
swap (public member function)
Non-member functions
make_tuple (function template)
tie (function template)
forward_as_tuple (function template)
tuple_cat (function template)
std::get(std::tuple) (function template)
operator==
operator!= lexicographically compares the values in the tuple
operator< (function template)
operator<=
operator>
operator>=
std::swap(std::tuple) specializes the std::swap algorithm
(C++11)
Helper classes
tuple_size (class template specialization)
tuple_element (class template specialization)
std::uses_allocator<std::tuple> specializes the std::uses_allocator type trait
(C++11)
ignore (constant)
Deduction_guides(since C++17)
Notes
Until C++17, a function could not return a tuple using list-initialization:
std::tuple<int, int> foo_tuple()
{
return {1, -1}; // Error until C++17
return std::make_tuple(1, -1); // Always works
}
Example
// Run this code
#include <tuple>
#include <iostream>
#include <string>
#include <stdexcept>
std::tuple<double, char, std::string> get_student(int id)
{
if (id == 0)
return std::make_tuple(3.8, 'A', "Lisa Simpson");
if (id == 1)
return std::make_tuple(2.9, 'C', "Milhouse Van Houten");
if (id == 2)
return std::make_tuple(1.7, 'D', "Ralph Wiggum");
throw std::invalid_argument("id");
}
int main()
{
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';
double gpa1;
char grade1;
std::string name1;
std::tie(gpa1, grade1, name1) = get_student(1);
std::cout << "ID: 1, "
<< "GPA: " << gpa1 << ", "
<< "grade: " << grade1 << ", "
<< "name: " << name1 << '\n';
// C++17 structured binding:
auto [gpa2, grade2, name2] = get_student(2);
std::cout << "ID: 2, "
<< "GPA: " << gpa2 << ", "
<< "grade: " << grade2 << ", "
<< "name: " << name2 << '\n';
}
Output:
References
* C++11 standard (ISO/IEC 14882:2011):
