#include "stdafx.h" ?ae[dif
y~==waZw
#include <iostream> B@"SOX
#include <fstream> TbKP8zw{
#include <sstream> r
1l/) ;
#include <iterator> l50|`
6t
using namespace std; 08Pt(kzNA
-~vl+L
int main(int argc, char* argv[]) RjR&D?dc
{ %k3NT~
ifstream ifs("test.txt"); ,>bGbx
if(!ifs) [)Z'N/;0
return false; cX|[WT0[I
.%x"t>]
ostringstream oss; ?qd,>
istream_iterator<char> inpos(ifs); W"b&M%y|
istream_iterator<char> endpos; QMXD9H0{
ostream_iterator<char> out(oss); *Fa)\.XX
std::copy(inpos, endpos, out); )K>Eniou
string& szData = oss.str(); 05l0B5'p
"8wf.nZ
const char * cc = szData.c_str(); B\=SAi
// cout << (long)szData << endl; tr6jh=
// cout << (long)oss.str().c_str() << endl; yCF"Z/.
cout<< cc; [+g(
TIcd
_>TW
return 0; ZQ,fm`y\
} dWsT Jyx~
E^Q@9C<!d
注意以上代码中红色部分没有写成: j!zA+hF(
const char * cc = oss.str().c_str(); // error g,t3OnxS?
要注意,oss.str()是值返回,所以这里会生成一个临时变量,此时cc中的值是该临时变量的内存地址。所以当此句执行完成后,临时变量被销毁,cc便失效。
Veb+^&
所以要先对该临时变量声明一个引用,此时该临时变量的生命周期便和szData一样,所以这样取到的cc所指向的内存才是有效的。