#include "stdafx.h" #2%([w
NyPd5m:
#include <iostream> }C(5 -7
#include <fstream> 3#.\
#include <sstream> M1u{A^d.Z
#include <iterator> W."f8ow
using namespace std; -)w]a{F
.`C
V^\
int main(int argc, char* argv[]) @Z\~
{ S]2 {ZDP
ifstream ifs("test.txt"); \3PE+$
if(!ifs) -fIc4u[
return false; w}<^l
NW.XA! =E)
ostringstream oss; 0\a8}b||
istream_iterator<char> inpos(ifs); [N|xzMe
istream_iterator<char> endpos; !0fI"3P@r
ostream_iterator<char> out(oss); x,Y5U+]E
std::copy(inpos, endpos, out); h[=nx^
string& szData = oss.str(); 6f]r Q9
yBn_Kd
const char * cc = szData.c_str(); jM__{z
// cout << (long)szData << endl; d(L{!mm
// cout << (long)oss.str().c_str() << endl; @"1}16b#f
cout<< cc; m@oUvxcd
d5U; $q{o
return 0; }e=e",eAT
} 5()Fvae{k
yr4ou
注意以上代码中红色部分没有写成: MEU[%hty_
const char * cc = oss.str().c_str(); // error J_ V,XO
要注意,oss.str()是值返回,所以这里会生成一个临时变量,此时cc中的值是该临时变量的内存地址。所以当此句执行完成后,临时变量被销毁,cc便失效。 zLek&s&-
所以要先对该临时变量声明一个引用,此时该临时变量的生命周期便和szData一样,所以这样取到的cc所指向的内存才是有效的。