#include "stdafx.h" $_UF9l0
pQ hv3F
#include <iostream> GgYomR:
#include <fstream> }?^G=IP4(
#include <sstream> eyWwE%
#include <iterator> DQ}]'*@?
using namespace std; ]7O?c=
-|kDa1knA
int main(int argc, char* argv[]) Glr.)PA
{ sig_2;
ifstream ifs("test.txt"); w?C\YKF7
if(!ifs) ?m.4f&X
return false; $p@g#3X`
{Q"<q`c
ostringstream oss; tpD?-`9o
istream_iterator<char> inpos(ifs); StVv"YY
istream_iterator<char> endpos; *%e#)sn*
ostream_iterator<char> out(oss); -d~'tti
std::copy(inpos, endpos, out); m}E$6E^~O
string& szData = oss.str(); koU.`l.
z,EOyi
const char * cc = szData.c_str(); !]nCeo
// cout << (long)szData << endl; (qrT0D6
// cout << (long)oss.str().c_str() << endl; 5W48z%MN
cout<< cc; Z-?9F`}
3PGyqt(
return 0; ;FBc^*q
} pf_ /jR
gr=`_k4~1
注意以上代码中红色部分没有写成: >seB["C
const char * cc = oss.str().c_str(); // error BSY#xe V
要注意,oss.str()是值返回,所以这里会生成一个临时变量,此时cc中的值是该临时变量的内存地址。所以当此句执行完成后,临时变量被销毁,cc便失效。 m @%|Q;
所以要先对该临时变量声明一个引用,此时该临时变量的生命周期便和szData一样,所以这样取到的cc所指向的内存才是有效的。