#include "stdafx.h" Z5[f
8 aC]" C
#include <iostream> UEh-k"
#include <fstream> WEZ)>[Xj?
#include <sstream> ?S0gazZm
#include <iterator> y^tp^
using namespace std; \?K>~{)
5Vu@gRk_
int main(int argc, char* argv[]) <uL0M`u3
{ uEE#A0
ifstream ifs("test.txt"); k_A
9gj1
if(!ifs) 0o*
return false; QVJvuiUh
H'2Un(#Al
ostringstream oss; eGW~4zU
istream_iterator<char> inpos(ifs); +jrMvk"
istream_iterator<char> endpos; m
L,El2
ostream_iterator<char> out(oss); :978D0}{p
std::copy(inpos, endpos, out); =k|hH~
string& szData = oss.str(); y|O)i
I/g
P;~P:qKd
const char * cc = szData.c_str(); EVE<LF?
// cout << (long)szData << endl;
}29Cm$p
// cout << (long)oss.str().c_str() << endl; *=~X1s
cout<< cc; lBcRt)_O7
qcdENIy0b
return 0; A_}%YHb
} JzZ9ua
?:1)=I<A4
注意以上代码中红色部分没有写成: 1u\kxlZ
const char * cc = oss.str().c_str(); // error /&Vgo~.J
要注意,oss.str()是值返回,所以这里会生成一个临时变量,此时cc中的值是该临时变量的内存地址。所以当此句执行完成后,临时变量被销毁,cc便失效。 /ar/4\b
所以要先对该临时变量声明一个引用,此时该临时变量的生命周期便和szData一样,所以这样取到的cc所指向的内存才是有效的。