ofstream caout("E:\\aaa.txt");
caout<<bu;
ifstream cain("E:\\aaa.txt");
string bub;
cain>>bub;
         CString buc=bub.c_str(); m_b=buc;

——————
bu、m_b都是MFC里用的CString类型变量,
第二行用caout<<bu,成功地把bu的内容写到aaa.txt文件里了。
但是接下来,从aaa.txt里读出来的内容却没有进到m_b里面- -很郁闷。
求教一下各位高手,这是怎么回事。谢谢啦。顺便问一下,为啥可以直接把CString类型变量(bu)给写到文件里,却不能把文件里读出来的东西直接赋值到CString类型变量(buc)里……

解决方案 »

  1.   

    楼主,你上面是不是写的有点乱。为啥可以直接把CString类型变量(bu)给写到文件里。可以这样做是因为CString类重载了插入运算符,即<<这个。所以可以直接写给文件里。而提取运算符,即>>同样也重载了,你查看一下是不是你程序的问题。这个应该是都可以的了。
      

  2.   

    编码问题吧,你当前环境是Unicode编码的吧
      

  3.   

    要看你当前的编译环境,如果是Unicode的话,要将string转换成wstring
      

  4.   

    CString是单字节的, 你上面的程序是从文件中把值输入到string中, string有可能是双字节的
      

  5.   


    // 一件没有技术含量的事:CString->std::string 例子: CString strMfc=“test“; std::string strStl; strStl=strMfc.GetBuffer(0); unicode情形下:    CStringW strw = _T("test");
        CStringA stra(strw.GetBuffer(0));
        strw.ReleaseBuffer();    std::string imgpath=stra.GetBuffer(0);
        stra.ReleaseBuffer();std::string->CString   例子: CString strMfc; std::string strStl=“test“; strMfc=strStl.c_str(); AfxExtractSubString是截取字符串的函数,很好用,不过美中不足的地方在与它只能使用单个字符作为分割符。但是这种情况在很多时候都行不通,如果分割符需要是两个字符以上呢?之前因为这个问题试了很久,也在网上搜索过。不过可惜的是,网上的大部分关于VC截取字符串的文章都是那么同样的几篇,都是写的满复杂然后可以实现了AfxExtractSubString功能而已的,也就是只能用单个字符截取,但是标题却写着用字符串截取字符串,好笑!不找了,自己写吧。CString里面有Find,然后再组成数组。void Split(CString source, CStringArray& dest, CString division)
    ...{
         dest.RemoveAll();
        int pos = 0;
        int pre_pos = 0;
        while( -1 != pos )...{
             pre_pos = pos;
             pos = source.Find(division,(pos+1));
             dest.Add(source.Mid(pre_pos,(pos-pre_pos)));
         }}
    CString source是需要截取的原字符串,CStringArray& dest 是最终结果的数组CString division 是用来做分割符的字符串备忘:为了适用于Unicode环境,要养成使用_T()宏的习惯1、格式化字符串CString s;
    s.Format(_T("The num is %d."), i);2、转为 int转10进制最好用_ttoi(),它在 ANSI 编码系统中被编译成_atoi(),而在 Unicode 编码系统中编译成_wtoi()。用_tcstoul()或者_tcstol()可以把字符串转化成任意进制的(无符号/有符号)长整数。CString hex = _T("FAB");
    CString decimal = _T("4011");
    ASSERT(_tcstoul(hex, 0, 16) == _ttoi(decimal));3、转为 char *3.1 强制类型转换为 LPCTSTR,不能修改字符串LPCTSTR p = s; 或者直接 (LPCTSTR)s;3.2 使用 GetBuffer 方法不给 GetBuffer 传递参数时它使用默认值 0,意思是:“给我这个字符串的指针,我保证不加长它”。假设你想增加字符串的长度,就必须将你需要的字符空间大小(注意:是字符而不是字节,因为 CString 是以隐含方式感知 Unicode 的)传给它。当调用 ReleaseBuffer 时,字符串的实际长度会被重新计算,然后存入 CString 对象中。
    必须强调一点,在 GetBuffer 和 ReleaseBuffer 之间这个范围,一定不能使用你要操作的这个缓冲的 CString 对象的任何方法。因为 ReleaseBuffer 被调用之前,该 CString 对象的完整性得不到保障。LPTSTR p = s.GetBuffer();
    // do something with p
    int m = s.GetLength(); // 可能出错!!!
    s.ReleaseBuffer();
    int n = s.GetLength(); // 保证正确4、其他4.1 分割字符串AfxExtractSubString(CString& rString, LPCTSTR lpszFullString, int iSubString, TCHAR chSep = '\n');CString csFullString(_T("abcd-efg-hijk-lmn"));
    CString csTemp;
    AfxExtractSubString(csTemp, (LPCTSTR)csFullString, 0, '-'); // 得到 abcd
    AfxExtractSubString(csTemp, (LPCTSTR)csFullString, 1, '-'); // 得到 efg
    AfxExtractSubString(csTemp, (LPCTSTR)csFullString, 2, '-'); // 得到 hijk
    AfxExtractSubString(csTemp, (LPCTSTR)csFullString, 3, '-'); // 得到 lmn分隔符可以随便指定:
    AfxExtractSubString(csTemp, (LPCTSTR)csFullString, 0, 'f'); // 得到 abcd-e