我在编译的时候提示:error C3861: “UpdateData”: 找不到标识符
代码段如下:
CString m_Idc_Edput;
CString str;
UpdateData(true);//将输入的数据装入EditControl对应的变量m_Idc_Edput中
str=m_Idc_Edput.GetString();
str.ReleaseBuffer();//更新字符串的长度提示这种错误是因为没有添加头文件吗?谁能给我个详细的解决方法啊?
代码段如下:
CString m_Idc_Edput;
CString str;
UpdateData(true);//将输入的数据装入EditControl对应的变量m_Idc_Edput中
str=m_Idc_Edput.GetString();
str.ReleaseBuffer();//更新字符串的长度提示这种错误是因为没有添加头文件吗?谁能给我个详细的解决方法啊?
解决方案 »
- VC6.0调试的显示调用调试和隐式调用调试如何用的啊
- 如何把得到的关于网状图的数据形象展示出来
- 急救!!!正在用MFC写的程序中,某按钮控件单击消息突然不响应此按钮的单击动作了!!!???
- 帮帮我吧,不然我就失业啦?
- 這個函數取後邊的參數怎取? (10分)
- DLL 老大难 帮个忙,我的程序如下:
- 请问int(a)和(int) a有什么区别?两个各用在什么场合?
- ACTIVE MOVIE 控件支持RMVB格式吗????急
- 怎样区分接收到的不同的数据
- 求救,win2000server无spa版关机的时候总是到“你可以安全的关机了”的时候停,我还得自己关电源
- ACTIVE初学者请教
- MFC类引用的一个小问题
{
// 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里用到的。可是还是出现那样的错误提示,这是怎么回事啊?
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() 来包围格式化字符串,但是基本思路仍然是在走弯路,这这样很容易出错。