#include "stdafx.h" "&G/T ?4
A>o*t=5
#include <iostream> nxnv,AZG
#include <fstream> 5m&9"T. w
#include <sstream> `ZyI!"
#include <iterator> /
F4z g3
using namespace std; keL&b/@
!>..Q)z
int main(int argc, char* argv[]) @tNz Q8
{ k@ RDvn
ifstream ifs("test.txt"); 8]/bK5`
if(!ifs) _E@2ZnD2
return false;
_=F=`xu
cPyE 6\lN
ostringstream oss; X86O lP)eX
istream_iterator<char> inpos(ifs); D9^h;
8
istream_iterator<char> endpos; n|Q@UPb/=
ostream_iterator<char> out(oss); cUKE
std::copy(inpos, endpos, out); .WA-&b_
string& szData = oss.str(); CQF:Rnb
5Ha9lM2gh
const char * cc = szData.c_str(); g+vva"
// cout << (long)szData << endl; R O+GK`J
// cout << (long)oss.str().c_str() << endl; Lo{
E:5q
cout<< cc; S&Zm0Ku
vlmB`T
return 0; @E7DyU|
} Z'`<5A%;
0l )~i''
注意以上代码中红色部分没有写成: n'n/Tu
const char * cc = oss.str().c_str(); // error ;K:zmH
要注意,oss.str()是值返回,所以这里会生成一个临时变量,此时cc中的值是该临时变量的内存地址。所以当此句执行完成后,临时变量被销毁,cc便失效。 bzBEX mC
所以要先对该临时变量声明一个引用,此时该临时变量的生命周期便和szData一样,所以这样取到的cc所指向的内存才是有效的。