第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

MFC中CMap的使用問題。

MFC中CMap的使用問題。

C++
慕娘9325324 2018-07-18 13:18:13
本想用 char 字符串做主鍵。我定義了個(gè)類成員,類型: CMap《const char ※,const char ※,int,int》在類內(nèi)一個(gè)函數(shù)里 new 的 字符串 set 進(jìn)去,在另外一個(gè) 函數(shù)里 拿一個(gè)字符串去查找 就找不到了。。。難道要拿著那個(gè) set 進(jìn)去的指針去找么 ?我不知道想 用char 數(shù)組做主鍵應(yīng)該怎么定義,難道CMap不支持么?class CMyClass { public:     CMyClass();     ~CMyClass();     void Set(char * pname, int n);     int Get(char* pname);     CMap<const char*, const char*, int, int> m_mapTest; };  void CMyClass::Set(char * pname,int n) {     char* pName = new char[20]{ 0 };     strcpy_s(pName, 20, pname);     m_mapTest.SetAt(pName, n); } int CMyClass::Get(char* pname) {     POSITION pos = m_mapTest.GetStartPosition();     const char* pKey=NULL;     while (pos)     {         int n = 0;         m_mapTest.GetNextAssoc(pos, pKey, n);         if (strcmp(pKey, pname) == 0)             break;     }     int n = 0;     if (m_mapTest.Lookup(pKey, n))     {// 這里 可以進(jìn)來(lái),如果要這樣才能查找到對(duì)應(yīng)的value 我還用 CMap 干嘛。。。         int x = n;     }     if (m_mapTest.Lookup(pname, n))     {// 這里進(jìn)不來(lái)         int x = n;     }     return n; }
查看完整描述

1 回答

?
呼喚遠(yuǎn)方

TA貢獻(xiàn)1856條經(jīng)驗(yàn) 獲得超11個(gè)贊

之所以出現(xiàn)這個(gè)問題,是因?yàn)椋篊Map m_mapTest; 這樣的寫法表示Key的比較方式是按照地址的方式來(lái)查找,
即你set進(jìn)去的地址是多少,找的key的地址就應(yīng)該多少。
如果要以內(nèi)容比較的方式(即const char* 指向的字符串),用樓上說(shuō)的CString作為Key的定義去做。

以下的代碼的ptest_key是同一地址,并且改了Set函數(shù),直接將改地址存放作為Key,則可以找到的:
#include "stdafx.h"
#include

class CMyClass
{
public:
CMyClass() {}
~CMyClass() {}

void Set(char * pname, int n);

int Get(const char* pname);

CMap<const char*, const char*, int, int> m_mapTest;

};

void CMyClass::Set(char * pname, int n)
{
char* pName = new char[20]{ 0 };
strcpy_s(pName, 20, pname);
//m_mapTest.SetAt(pName, n);
m_mapTest.SetAt(pname, n);
}

int CMyClass::Get(const char* pname)
{
POSITION pos = m_mapTest.GetStartPosition();
const char* pKey = NULL;
while (pos)
{
int n = 0;
m_mapTest.GetNextAssoc(pos, pKey, n);
if (strcmp(pKey, pname) == 0)
break;
}

int n = 0;
if (m_mapTest.Lookup(pKey, n))
{// 這里 可以進(jìn)來(lái),如果要這樣才能查找到對(duì)應(yīng)的value 我還用 CMap 干嘛。。。
    int x = n;
}

if (m_mapTest.Lookup(pname, n))
{// 這里進(jìn)不來(lái)
    int x = n;
}

return n;

}
int main()
{
char * ptest_key = "我是誰(shuí)?";
CMyClass c;
c.Set(ptest_key, 1);
c.Get(ptest_key);
return 0;
}


查看完整回答
反對(duì) 回復(fù) 2018-07-27
  • 1 回答
  • 0 關(guān)注
  • 1283 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)