#include "stdafx.h" &? z6f9*$
U( (F<
#include <iostream> Wer.VL
#include <fstream> ;H`>jI$
#include <sstream> 1gh<nn
#include <iterator> G21cJi*
using namespace std; 7yFV.#K3O
c~v(bK
int main(int argc, char* argv[]) F8OE
{ 1zWEK]2.R
ifstream ifs("test.txt"); We:b1sZR
if(!ifs) -=VGXd
return false; tY0C& u2
e> Q_&6L
ostringstream oss; b^C2<'
istream_iterator<char> inpos(ifs); 'G8.)eTA'
istream_iterator<char> endpos; [.LbX`K:
ostream_iterator<char> out(oss); B^lm'/,@
std::copy(inpos, endpos, out); (C60HbL
string& szData = oss.str(); zMbz_22*
9xM7X?
const char * cc = szData.c_str(); /8"9sf*
// cout << (long)szData << endl; NTy0NH
// cout << (long)oss.str().c_str() << endl; sFa5#w*>
cout<< cc; $^louas&
B,avI&7M;S
return 0; Jwe9L^gL
} KV]8o'
C
]+J
注意以上代码中红色部分没有写成: | x/Z
qY
const char * cc = oss.str().c_str(); // error ?nV& :~eY
要注意,oss.str()是值返回,所以这里会生成一个临时变量,此时cc中的值是该临时变量的内存地址。所以当此句执行完成后,临时变量被销毁,cc便失效。 THf*<|
所以要先对该临时变量声明一个引用,此时该临时变量的生命周期便和szData一样,所以这样取到的cc所指向的内存才是有效的。