#include "stdafx.h" pZy~1L
?&1!vz
#include <iostream> pYf-S?Y/V
#include <fstream> Qzw;i8n{
#include <sstream> /mzlH
#include <iterator> NTs aW}g
using namespace std; Z(CkZll
"=Me M)K
int main(int argc, char* argv[]) e$rZ5X
{ b d!Y\OD
ifstream ifs("test.txt"); t"oeQ*d%
if(!ifs) I-l_TpM)
return false; &{t,' [ u
M9%$lCl
ostringstream oss; 5:_}zu|!u
istream_iterator<char> inpos(ifs); e+fN6v5pU
istream_iterator<char> endpos; NK
H@+,+V
ostream_iterator<char> out(oss); C$`tbq
std::copy(inpos, endpos, out); ' S/gmn
string& szData = oss.str(); fe_5LC"
X#^[<5
const char * cc = szData.c_str(); Slc\&Eb
// cout << (long)szData << endl; om:VFs\U
// cout << (long)oss.str().c_str() << endl; "VMz]ybi^
cout<< cc; 6(-N FnT
K[zVa
return 0; bV3|6]k^
} Pa:|_IXA
9_/:[N6|c|
注意以上代码中红色部分没有写成: FGq[\B
const char * cc = oss.str().c_str(); // error .HABNPNg(
要注意,oss.str()是值返回,所以这里会生成一个临时变量,此时cc中的值是该临时变量的内存地址。所以当此句执行完成后,临时变量被销毁,cc便失效。 iDqoa\
所以要先对该临时变量声明一个引用,此时该临时变量的生命周期便和szData一样,所以这样取到的cc所指向的内存才是有效的。