#include "stdafx.h" m_BpY9c]5
U>m{B|H
#include <iostream> Aayd3Ph0%
#include <fstream> 1$6
u
#include <sstream> MpvGF7H
#include <iterator> w^YXnLLJG
using namespace std; 6E:H
/C5py-I
int main(int argc, char* argv[]) bn5O2
{ qt/6o|V
ifstream ifs("test.txt"); PMW@xk^<Y
if(!ifs) >K1e=SY
return false; p9mGiK4!
yOvV"x]
ostringstream oss; DIWyv-
istream_iterator<char> inpos(ifs); ,j\uvi(Y
istream_iterator<char> endpos; v0tFU!Q%
ostream_iterator<char> out(oss); dLwP7#r
std::copy(inpos, endpos, out); 8*&73cp
string& szData = oss.str(); )
LTV+?
ko'V8r`V
const char * cc = szData.c_str(); !M9mX%UQ
// cout << (long)szData << endl; QZa^Cng~
// cout << (long)oss.str().c_str() << endl; aI`d
cout<< cc; Yl?s^]SFU
:,j^ei
return 0; b9 li
} )1R[X!KQ7
Tyb'p9
注意以上代码中红色部分没有写成: riaL[4c
const char * cc = oss.str().c_str(); // error f~TkU\Rh
要注意,oss.str()是值返回,所以这里会生成一个临时变量,此时cc中的值是该临时变量的内存地址。所以当此句执行完成后,临时变量被销毁,cc便失效。 2Ur&_c6P
所以要先对该临时变量声明一个引用,此时该临时变量的生命周期便和szData一样,所以这样取到的cc所指向的内存才是有效的。