#include "stdafx.h" _E<O+leWf
GlgORy=>
#include <iostream> +JAfHQm-
#include <fstream> VBsFT2XiL
#include <sstream> b:5%}
#include <iterator> [xs)u3b
using namespace std; QRZTT qG
(:bCOEZ
int main(int argc, char* argv[]) *ez~~ Y
{ '"fU2M<.
ifstream ifs("test.txt"); nP{sCH 1
if(!ifs) tTh;.88Z{
return false; 0CVsDVA
z0Z\d
ostringstream oss; 7- 3N
istream_iterator<char> inpos(ifs); 0e:QuV2X
istream_iterator<char> endpos; z'}= A
ostream_iterator<char> out(oss); c;8"vJ
std::copy(inpos, endpos, out); a2=uM}Hsp
string& szData = oss.str(); K-Dk2(x
Or#+E2%1E
const char * cc = szData.c_str(); #
/,2MQ
// cout << (long)szData << endl; {{[jC"4AY
// cout << (long)oss.str().c_str() << endl; g*r{!:,t
cout<< cc; VRQbf
B/9<b{6
return 0; IU'!?XVo
} N"
Jtg@w
MHr0CYyb.
注意以上代码中红色部分没有写成: XG\a-dq[
const char * cc = oss.str().c_str(); // error Vh.;p.!e
要注意,oss.str()是值返回,所以这里会生成一个临时变量,此时cc中的值是该临时变量的内存地址。所以当此句执行完成后,临时变量被销毁,cc便失效。 OxHw1k
所以要先对该临时变量声明一个引用,此时该临时变量的生命周期便和szData一样,所以这样取到的cc所指向的内存才是有效的。