#include "stdafx.h" CKgyv%T5m:
e#{L~3
#include <iostream> l>q.BG
#include <fstream> :g_ +{4
#include <sstream> d^>s e'ya
#include <iterator> roQIP%h!
using namespace std; a)b@en;v
<{j9|mt
int main(int argc, char* argv[])
A(5?
ci
{ > xw+2<
ifstream ifs("test.txt"); vi|ASA{V
if(!ifs) U {v_0\ES
return false; Gu=bPQOj
{'[1I_3
ostringstream oss; S_=u v)%a
istream_iterator<char> inpos(ifs); 9rz "@LM
istream_iterator<char> endpos; r&;AG@N/
ostream_iterator<char> out(oss); YSmz)YfX9
std::copy(inpos, endpos, out); ](pD<FfS]'
string& szData = oss.str(); -n-X/M
E ..[F<5
const char * cc = szData.c_str(); g`8|jg0]`I
// cout << (long)szData << endl; #UIg<:
// cout << (long)oss.str().c_str() << endl; &*~
WK
cout<< cc; `dhK$jYD
h#9)M
return 0; G<DUy^$i
} 7ac3N
/8R1$7
注意以上代码中红色部分没有写成: E u
const char * cc = oss.str().c_str(); // error (re D
要注意,oss.str()是值返回,所以这里会生成一个临时变量,此时cc中的值是该临时变量的内存地址。所以当此句执行完成后,临时变量被销毁,cc便失效。 i"@?eq#h
所以要先对该临时变量声明一个引用,此时该临时变量的生命周期便和szData一样,所以这样取到的cc所指向的内存才是有效的。