漂亮印刷std::tuple
在上一個關於美化STL 容器的問題中,我們成功開發了一個全面且優雅的解決方案。下一步將深入研究使用可變參數模板(僅適用於 C 11)的漂亮列印 std::tuple 的領域。
背景
對於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中文網其他相關文章!