Pretty-Printing std::tuple
STL 컨테이너 장식에 대한 이전 질문에서 우리는 포괄적이고 우아한 솔루션을 성공적으로 개발했습니다. 다음 단계에서는 가변 템플릿(C 11에만 해당)을 사용하여 std::tuple을 예쁘게 인쇄하는 영역을 살펴봅니다.
Background
std::pair의 경우 구문은 간단합니다.
std::ostream & operator<<(std::ostream &, const std::pair<S, T> &);
튜플
퍼즐은 튜플을 인쇄하기 위한 유사한 구성을 정의하는 데 있습니다. 우리는 이 동작을 목표로 합니다:
auto a = std::make_tuple(5, "Hello", -0.1); std::cout << a << std::endl; // prints: (5, "Hello", -0.1)
솔루션
답은 인덱스 활용에 있습니다:
namespace aux{ template<std::size_t... Is> struct seq{}; template<std::size_t N, std::size_t... Is> struct gen_seq : gen_seq<N-1, N-1, Is...>{}; template<std::size_t... Is> struct gen_seq<0, Is...>: seq<Is...>{}; template<class Ch, class Tr, class Tuple, std::size_t... Is> void print_tuple(std::basic_ostream<Ch, Tr>& os, Tuple const& t, seq<Is...>){ using swallow = int[]; (void)swallow{0, (void(os << (Is == 0? "": ", ") << std::get<Is>(t)), 0)...}; } } // aux:: template<class Ch, class Tr, class... Args> auto operator<<(std::basic_ostream<Ch, Tr>& os, std::tuple<Args...> const& t) -> std::basic_ostream<Ch, Tr>& { os << "("; aux::print_tuple(os, t, aux::gen_seq<sizeof...(Args)>()); return os << ")"; }
보너스: 구분 기호
유연성을 더하기 위해 부분적으로 전문화:
// Delimiters for tuple template<class... Args> struct delimiters<std::tuple<Args...>, char> { static const delimiters_values<char> values; }; template<class... Args> const delimiters_values<char> delimiters<std::tuple<Args...>, char>::values = { "(", ", ", ")" }; template<class... Args> struct delimiters<std::tuple<Args...>, wchar_t> { static const delimiters_values<wchar_t> values; }; template<class... Args> const delimiters_values<wchar_t> delimiters<std::tuple<Args...>, wchar_t>::values = { L"(", L", ", L")" };
결론
위의 수정을 통해 std::tuple을 예쁘게 인쇄하여 다양한 문자 세트와 구분 기호 기본 설정을 수용하도록 사용자 정의할 수 있습니다. 우아하고 다재다능한 솔루션입니다.
위 내용은 C 11에서 가변 템플릿을 사용하여 `std::tuple`을 어떻게 예쁘게 인쇄할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!