boost::string_algo详解7——join的应用

本文介绍使用Boost库中的join及join_if函数来连接字符串序列的方法,并通过具体示例展示了如何利用这些函数来灵活地处理字符串集合。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  1. template<typename SequenceSequenceT, typename Range1T>  
  2.   range_value< SequenceSequenceT >::type  
  3.   join(const SequenceSequenceT & Input, const Range1T & Separator);  
  4.   
  5. template<typename SequenceSequenceT, typename Range1T, typename PredicateT>  
  6.   range_value< SequenceSequenceT >::type  
  7.   join_if(const SequenceSequenceT & Input, const Range1T & Separator,PredicateT Pred);  

例子:

  1. void test_string_join()  
  2. {  
  3.     using namespace boost::assign;  
  4.     std::vector<std::string> v = list_of("Samus")("Link")("Zelda")("Mario");  
  5.   
  6.     std::copy(v.cbegin(), v.cend(), std::ostream_iterator<std::string>(std::cout, " "));  
  7.     std::cout << std::endl;  
  8.   
  9.     std::cout << boost::join(v, ", ") << std::endl;  
  10.   
  11.     struct is_contains_a  
  12.     {  
  13.         bool operator() (const std::string &x)  
  14.         {  
  15.             return boost::contains(x, "a");  
  16.         }  
  17.     };  
  18.     std::cout << boost::join_if(v, "__", is_contains_a()) << std::endl;  
  19. }  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值