2010-02-13 67 views
6

我想写出这样的事情,这不能被编译:结合的boost :: lexical_cast的和std ::变换

std::vector<A> as; 
std::vector<B> bs(as.size()); 
std::transform(as.beginn(), as.end(), bs.begin(), boost::lexical_cast<B>); 

但是这是行不通的,所以我创建了一个函子这是做这个的me:

template<typename Dest> 
struct lexical_transform 
{ 
    template<typename Src> 
    Dest operator()(const Src& src) const 
    { 
     return boost::lexical_cast<Dest>(src); 
    } 
}; 

有没有更简单的方法来做到这一点?

回答

16

lexical_cast有两个模板参数:目标类型和源类型。在正常使用情况下,第二个从呼叫中推断出来。

不过,在这里你想利用函数的地址,你需要指定所有的模板参数:

std::transform(as.begin(), as.end(), bs.begin(), boost::lexical_cast<B, A>); 
+0

日Thnx了很多,它的作品完美 – 2010-02-13 21:10:57

1

如果你做这样的事情很多,你可能要考虑的Boost.Convert库(不是Boost的可接受部分)。从手动查看此示例:

std::transform(strings.begin(), strings.end(), 
       std::back_inserter(integers), 
       boost::convert<int>::from<string>()); 
+0

是有优势相比,UncleBens给出的方法呢? – 2010-02-13 21:11:28

+0

一般来说,它并不是真的适合你的例子,它给你更多的力量。例如,你可以使用像std :: hex这样的IO操纵器,或者指定一个在转换不可用的情况下使用的默认值 – Manuel 2010-02-14 07:11:31

相关问题