#include "stdafx.h" pC.T)k
M4PUJZ]
#include <iostream> &B,& *Lp
#include <fstream> .E8p-R5)V>
#include <sstream> EuA<{%i
#include <iterator> 7?WBzo!!L
using namespace std; w=>mG-
+rO<'H:umJ
int main(int argc, char* argv[]) o[ W3/
{ g-gBg\y{v
ifstream ifs("test.txt"); cZT.vA#
if(!ifs) l5nDt$Ex
return false; ]@}BdMlHp
)P+GklI{4
ostringstream oss; 3NZFW{u
istream_iterator<char> inpos(ifs); wupD
istream_iterator<char> endpos; R'HA>?D
ostream_iterator<char> out(oss); \ OINzfbr
std::copy(inpos, endpos, out); AFUl
string& szData = oss.str(); ^b.
MR ?9
t"vO&+x
const char * cc = szData.c_str(); Z6@J-<u
// cout << (long)szData << endl; 'yjH~F.
// cout << (long)oss.str().c_str() << endl; !#s7 F
cout<< cc; [t)i\ }V
Rw8m5U
return 0; Q31c@t
} oT{yttSNo
ZTC1t_
注意以上代码中红色部分没有写成: z6r/
w
const char * cc = oss.str().c_str(); // error ,PxQ[CGg
要注意,oss.str()是值返回,所以这里会生成一个临时变量,此时cc中的值是该临时变量的内存地址。所以当此句执行完成后,临时变量被销毁,cc便失效。 w o9f99
所以要先对该临时变量声明一个引用,此时该临时变量的生命周期便和szData一样,所以这样取到的cc所指向的内存才是有效的。