#include "stdafx.h" FY+0r67]
AX,V*
s
#include <iostream> =v]\{.
#include <fstream> Z5/^pyc
#include <sstream> <]xGd!x$
#include <iterator> _>+!&_h
using namespace std; q@8Jc[\d
]Qm$S5tU
int main(int argc, char* argv[]) d,AEV_
{ `w';}sQA7
ifstream ifs("test.txt"); bYQvh/(J
if(!ifs) 0F> ils
return false; 35;|r
}7&.FV"
ostringstream oss; W{:^P0l
istream_iterator<char> inpos(ifs); 89o&KF]
istream_iterator<char> endpos; i#]}k
ostream_iterator<char> out(oss); &~)PB
|
std::copy(inpos, endpos, out); zrVw l\&
string& szData = oss.str(); ,r^zDlS<q
R?Zv
const char * cc = szData.c_str(); EK`}?>'
// cout << (long)szData << endl; o~<Xc
// cout << (long)oss.str().c_str() << endl; uNSaw['0j
cout<< cc; CAg~K[
k8IhQ{@
return 0; sh;DCd
} 1c8Nr&Jl
E#}OIZ\S
注意以上代码中红色部分没有写成: UtPFkase
const char * cc = oss.str().c_str(); // error nX%b@cOXj
要注意,oss.str()是值返回,所以这里会生成一个临时变量,此时cc中的值是该临时变量的内存地址。所以当此句执行完成后,临时变量被销毁,cc便失效。 .UX`@Q:Gp
所以要先对该临时变量声明一个引用,此时该临时变量的生命周期便和szData一样,所以这样取到的cc所指向的内存才是有效的。