CMapStringToOb::SetAt
Birincil bir harita bir öğe eklemek anlamına gelir.
void SetAt(
LPCTSTR key,
CObject* newValue
);
Parametreler
key
Yeni öğe anahtar dizesini belirtir.newValue
Belirtir CObject yeni öğe değerinin işaretçi.
Notlar
İlk olarak, anahtar aranmadan.Sonra da karşılık gelen değeri değiştirildiğinde anahtar bulunması durumunda; Aksi takdirde yeni bir anahtar-değer öğesi oluşturulur.
Diğer üye benzer işlevleri aşağıdaki tabloda gösterilmektedir CMapStringToOb::SetAt.
Sınıf |
Üye işlevi |
---|---|
void SetAt( void* key, void* newValue ); |
|
void SetAt( void* key, WORD newValue ); |
|
void SetAt( LPCTSTR key, void* newValue ); |
|
void SetAt( LPCTSTR key, LPCTSTR newValue ); |
|
void SetAt( WORD key, CObject* newValue ); |
|
void SetAt( WORD key, void* newValue ); |
Örnek
Bkz: CObList::CObList bir listesi için CAge tüm koleksiyon örneklerde kullanılan sınıf.
CMapStringToOb map;
CAge* pa;
map.SetAt(_T("Bart"), new CAge(13));
map.SetAt(_T("Lisa"), new CAge(11)); // Map contains 2
// elements.
#ifdef _DEBUG
afxDump.SetDepth(1);
afxDump << _T("before Lisa's birthday: ") << &map << _T("\n");
#endif
if (map.Lookup(_T("Lisa"), (CObject *&)pa))
{ // CAge 12 pointer replaces CAge 11 pointer.
map.SetAt(_T("Lisa"), new CAge(12));
delete pa; // Must delete CAge 11 to avoid memory leak.
}
#ifdef _DEBUG
afxDump << _T("after Lisa's birthday: ") << &map << _T("\n");
#endif
Bu programdan sonuçlar aşağıdaki gibidir:
before Lisa's birthday: A CMapStringToOb with 2 elements
[Lisa] = a CAge at $493C 11
[Bart] = a CAge at $4654 13
after Lisa's birthday: A CMapStringToOb with 2 elements
[Lisa] = a CAge at $49C0 12
[Bart] = a CAge at $4654 13
Gereksinimler
Başlık: afxcoll.h