我在编译的时候提示:error C3861: “UpdateData”: 找不到标识符
   代码段如下:
         CString m_Idc_Edput;
CString str;
UpdateData(true);//将输入的数据装入EditControl对应的变量m_Idc_Edput中
str=m_Idc_Edput.GetString();
str.ReleaseBuffer();//更新字符串的长度提示这种错误是因为没有添加头文件吗?谁能给我个详细的解决方法啊?
   

解决方案 »

  1.   

    这和头文件没有关系,这个函数是属于CDialog的,你必须在CDialog派生类的函数内使用
      

  2.   

    而且你这个代码要ReleaseBuffer干吗?
      

  3.   

    UpdateData是CWnd的成员函数,我调用它的地方是在CWnd类或是CWnd类的子类中吗?
      

  4.   

    楼上的几位说得已经很清楚了   你调用的地方要是没有CxxxDlg这个是不行的
      

  5.   

    void CworkDlg::OnBnClickedButtom()
    {
    // TODO: 在此添加控件通知处理程序代码
    CString m_Idc_Edput;
    CString str;
    // MessageBox(str,_T("获取编辑框的内容"),MB_OK);
    UpdateData(true);//将输入的数据装入EditControl对应的变量m_Idc_Edput中
    str=m_Idc_Edput.GetString();
    str.ReleaseBuffer();//更新字符串的长度 //连接数据库的设置
    char servername[]="172.17.6.103,2433";//IP地址和端口号2433
    char username[]="sa";//用户名
    char password[]="123456";//用户密码
    char database[]="cargo";//数据库名

    SQLServerDB db;
    _RecordsetPtr pRec;
        CListBox m_Idc_Lioutm;
    db.Initial(servername,database,username,password);
    pRec=db.Query("select * from dbo.master_table_shandonglangjin where mastername=str");//按条件查询

    _variant_t var;
    CString t_idno,t_name; int i=0;
    while (!pRec->EndOfFile&&i++<5)
    {
            var = pRec->GetCollect("id");//获取表的ID号
    if(var.vt !=VT_NULL)
    t_idno=(LPCSTR)_bstr_t(var);//将ID号赋值给变量t_idno
            var = pRec->GetCollect("mastername");//获得名称
    if(var.vt!=VT_NULL)
            t_name=(LPCSTR)_bstr_t(var);//将名称赋值给变量t_name
    m_Idc_Lioutm.AddString(t_idno+"-->"+t_name);//添加到控件ListBox中显示出来
    pRec->MoveNext();//指向下一条
        }
    m_Idc_Lioutm.SetCurSel(0);//默认列表指向第一项,同事移动记录指针并显示这是整段代码,它是在CworkDlg里用到的。可是还是出现那样的错误提示,这是怎么回事啊?
      

  6.   

    用到GetBuffer的时候,才会ReleaseBuffer
      

  7.   

    ④ CString转化成char* 之二:使用 CString 对象的 GetBuffer 方法  如果你需要修改 CString 中的内容,它有一个特殊的方法可以使用,那就是 GetBuffer,它的作用是返回一个可写的缓冲指针。 如果你只是打算修改字符或者截短字符串,你完全可以这样做:CString s(_T("File.ext"));
    LPTSTR p = s.GetBuffer();
    LPTSTR dot = strchr(p, ''.''); // OK, should have used s.Find...
    if(p != NULL)
    *p = _T(''\0'');
    s.ReleaseBuffer();  这是 GetBuffer 的第一种用法,也是最简单的一种,不用给它传递参数,它使用默认值 0,意思是:“给我这个字符串的指针,我保证不加长它”。当你调用 ReleaseBuffer 时,字符串的实际长度会被重新计算,然后存入 CString 对象中。
      必须强调一点,在 GetBuffer 和 ReleaseBuffer 之间这个范围,一定不能使用你要操作的这个缓冲的 CString 对象的任何方法。因为 ReleaseBuffer 被调用之前,该 CString 对象的完整性得不到保障。研究以下代码:CString s(...);LPTSTR p = s.GetBuffer();//... 这个指针 p 发生了很多事情int n = s.GetLength(); // 很糟D!!!!! 有可能给出错误的答案!!!s.TrimRight(); // 很糟!!!!! 不能保证能正常工作!!!!s.ReleaseBuffer(); // 现在应该 OKint m = s.GetLength(); // 这个结果可以保证是正确的。s.TrimRight(); // 将正常工作。  假设你想增加字符串的长度,你首先要知道这个字符串可能会有多长,好比是声明字符串数组的时候用:char buffer[1024];表示 1024 个字符空间足以让你做任何想做得事情。在 CString 中与之意义相等的表示法:LPTSTR p = s.GetBuffer(1024);  调用这个函数后,你不仅获得了字符串缓冲区的指针,而且同时还获得了长度至少为 1024 个字符的空间(注意,我说的是“字符”,而不是“字节”,因为 CString 是以隐含方式感知 Unicode 的)。
      同时,还应该注意的是,如果你有一个常量串指针,这个串本身的值被存储在只读内存中,如果试图存储它,即使你已经调用了 GetBuffer ,并获得一个只读内存的指针,存入操作会失败,并报告存取错误。我没有在 CString 上证明这一点,但我看到过大把的 C 程序员经常犯这个错误。
      C 程序员有一个通病是分配一个固定长度的缓冲,对它进行 sprintf 操作,然后将它赋值给一个 CString:char buffer[256];
    sprintf(buffer, "%......", args, ...); // ... 部分省略许多细节
    CString s = buffer;虽然更好的形式可以这么做:CString s;
    s.Format(_T("%...."), args, ...);如果你的字符串长度万一超过 256 个字符的时候,不会破坏堆栈。  另外一个常见的错误是:既然固定大小的内存不工作,那么就采用动态分配字节,这种做法弊端更大:int len = lstrlen(parm1) + 13 +lstrlen(parm2) + 10 + 100;char * buffer = new char[len];sprintf(buffer, "%s is equal to %s, valid data", parm1, parm2);CString s = buffer;......delete [] buffer;它可以能被简单地写成:CString s;s.Format(_T("%s is equal to %s, valid data"), parm1, parm2);  需要注意 sprintf 例子都不是 Unicode 就绪的,尽管你可以使用 tsprintf 以及用 _T() 来包围格式化字符串,但是基本思路仍然是在走弯路,这这样很容易出错。