一个由string使用不当产生的问题

今天因不正确的使用std::string,产生一个很难发觉的问题,搞了许久,mark一下。 原代码大概如下:

void func(char *buf, int len){

string s;

s.reserve(len);

memcpy((char *)&s[0], buf, len));

string t(s, 0, len);

}

发现t中的数据始终为空。 最后才明白,reserve函数没有更改string的size,也就是说s.size()==0, 后面其它字符串通过string的方法从s获取数据,由于size为零,都不能真正拷贝数据。 解决方法很简单,将reserve换成resize即可。可参考resize的源码:

    610   template<typename _CharT, typename _Traits, typename _Alloc>
611 void
612 basic_string<_CharT, _Traits, _Alloc>::
613 resize(size_type __n, _CharT __c)
614 {
615 const size_type __size = this->size();
616 _M_check_length(__size, __n, "basic_string::resize");
617 if (__size < __n)
618 this->append(__n - __size, __c);
619 else if (__n < __size)
620 this->erase(__n);
621 // else nothing (in particular, avoid calling _M_mutate() unnecessarily.)
622 } // /usr/include/c++/4.1.0/bits/basic_string.tcc
posted @ 2011-12-29 19:37  YY哥  阅读(2095)  评论(0编辑  收藏  举报