#include "stdafx.h" >cRE$d?
k(%h{0'
#include <iostream> x>*#cOVz;C
#include <fstream>
M;zJ1
#include <sstream> ~Lf>/w
#include <iterator> X9/]<Y<!
using namespace std; c/ s$*"
^y p`<=
int main(int argc, char* argv[])
v+qHH8
{ +?R!
ifstream ifs("test.txt"); bZ_vb? n
if(!ifs) Df_*W"(v
return false; VFjNrngl
3*;S%1C^
ostringstream oss; |8s45g>
istream_iterator<char> inpos(ifs); DqbU$jt`
istream_iterator<char> endpos; +y\mlfJ.-b
ostream_iterator<char> out(oss); !K5D:x
std::copy(inpos, endpos, out); i\94e{uty[
string& szData = oss.str(); &I=F4 z
LG>lj$hO
const char * cc = szData.c_str(); -na oM
// cout << (long)szData << endl; <[w>Mbqj_
// cout << (long)oss.str().c_str() << endl; n1
kh8,
cout<< cc; YDoVm?
hB 36o9|9
return 0; OF/DI)j3
} -]e@FNL
[lbe_G;
注意以上代码中红色部分没有写成: >+E
const char * cc = oss.str().c_str(); // error `6B jNV
要注意,oss.str()是值返回,所以这里会生成一个临时变量,此时cc中的值是该临时变量的内存地址。所以当此句执行完成后,临时变量被销毁,cc便失效。 SJ;Kjq.Qo
所以要先对该临时变量声明一个引用,此时该临时变量的生命周期便和szData一样,所以这样取到的cc所指向的内存才是有效的。