国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務(wù)器之家:專(zhuān)注于服務(wù)器技術(shù)及軟件下載分享
分類(lèi)導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語(yǔ)言|JavaScript|易語(yǔ)言|vb.net|

服務(wù)器之家 - 編程語(yǔ)言 - C/C++ - 深入C++ 函數(shù)映射的使用詳解

深入C++ 函數(shù)映射的使用詳解

2020-12-18 14:46C語(yǔ)言教程網(wǎng) C/C++

我比較喜歡用代碼結(jié)合實(shí)際來(lái)講解,下面我將以一段事例代碼來(lái)講解如何使用這幾種映射

想想我們?cè)谟龅蕉嗾Z(yǔ)句分支時(shí)是不是首先想到的是 switc case 和 if else if ...
這2種方式在編碼方面確實(shí)簡(jiǎn)單少,但是當(dāng)分支達(dá)到一定數(shù)量后,特別是分支內(nèi)部有嵌套大段代碼或者再嵌套分支,代碼會(huì)顯得異常臃腫,十分難以維護(hù),對(duì)于if else if 語(yǔ)句過(guò)多的分支帶來(lái)過(guò)多的判定句,勢(shì)必會(huì)影響效率。

3種替代方法簡(jiǎn)述:
1.使用map,需要構(gòu)建樹(shù)和節(jié)點(diǎn),比數(shù)組的方式消耗更多的內(nèi)存,查詢時(shí)間復(fù)雜度為L(zhǎng)og(N),但擴(kuò)展起來(lái)方便。

2.使用數(shù)組,查詢直接索引定位, 一般來(lái)講我們是連續(xù)的初始化數(shù)組,也就意味索引(type_func)到函數(shù)的映射要連續(xù),
所以使用數(shù)組索引在擴(kuò)展上來(lái)講:例如增刪元素是稍微麻煩點(diǎn)的。

3. 使用C++的特性---抽象繼承來(lái)實(shí)現(xiàn),本文只講前2種的使用,這種方式以后再補(bǔ)充。

復(fù)制代碼 代碼如下:

// 動(dòng)物會(huì)一些動(dòng)作
enum type_func
{
 type_begin = -1,
 type_eat,
 type_sleep,
 type_walk,
 type_run,
 type_smile,
 type_cry,
 type_jump,
 type_max_size,
};
class CAnimal
{
public:
 typedef int (CAnimal::*ptr_func)(bool);
protected:
 static map<type_func,ptr_func> s_map;     
 static ptr_func     s_array[type_max_size];   
public:
 CAnimal()
 {
  memset(s_array,0,sizeof(s_array));
  Init(); 
 }
 // 需要映射函數(shù)的返回值 和 參數(shù)必須 統(tǒng)一
 int  eat  (bool= true)  { return printf("eatn") ,1; }
 int  sleep (bool= true)  { return printf("sleepn"),1; }
 int  walk (bool= true)  { return printf("walkn") ,1; }
 int  run  (bool= true)  { return printf("runn") ,1; }
 int  smile (bool= true)  { return printf("smilen"),1; }
 int  cry  (bool= true)  { return printf("cryn") ,1; }
 int  jump (bool= true)  { return printf("jumpn") ,1; }
 // 初始化
 void Init ()
 {
  s_map[type_eat]  = &CAnimal::eat;
  s_map[type_sleep] = &CAnimal::sleep;
  s_map[type_walk] = &CAnimal::walk;
  s_map[type_run]  = &CAnimal::run;
  s_map[type_smile] = &CAnimal::smile;
  s_map[type_cry]  = &CAnimal::cry;
  s_map[type_jump] = &CAnimal::jump;
  s_array[type_eat] = &CAnimal::eat;
  s_array[type_sleep] = &CAnimal::sleep;
  s_array[type_walk] = &CAnimal::walk;
  s_array[type_run] = &CAnimal::run;
  s_array[type_smile] = &CAnimal::smile;
  s_array[type_cry] = &CAnimal::cry;
  s_array[type_jump] = &CAnimal::jump;
 }
 // 一般做法是switc case 或者 if else... 
 // 其實(shí)這里看起來(lái)還不算糟糕,一方面這里我把每個(gè)模塊內(nèi)容都封裝到相應(yīng)函數(shù)了
 // 分支內(nèi)部才會(huì)看起來(lái)相對(duì)簡(jiǎn)潔,實(shí)際編碼中可能就不是你現(xiàn)在所看到的方式。
 void Process (type_func type)
 {
  switch (type)
  {
  case type_eat:  eat();  break;
  case type_sleep: sleep(); break;
  case type_walk:  walk();  break;
  case type_run:  run();  break;
  case type_smile: smile(); break;
  case type_cry:  cry();  break;
  case type_jump:  jump();  break;
  }
 }
 // 很熟悉的感覺(jué)吧! :)
 void Process2(type_func type)
 {
  if (type_eat == type)
  {
   eat();
  }
  else if (type_sleep == type)
  {
   sleep();
  }
  else if (type_walk == type)
  {
   walk();
  }
  else if (type_run == type)
  {
   run();
  }
  else if (type_smile == type)
  {
   smile();
  }
  else if (type_cry == type)
  {
   cry();
  }
  else if (type_jump == type)
  {
   jump();
  }
 }
 // 使用map 映射
 void ProcessByUseMap(int key, bool val)
 {
  map<type_func,ptr_func>::iterator it =  s_map.find((type_func)key);
  if (it != s_map.end())
  {
   ptr_func pFun = it->second;
   if (pFun) 
    (this->*pFun)(val);
  }
 }
 // 使用數(shù)組 映射
 void ProcessByUseArray(int key, bool val)
 {
  // 數(shù)組
  if (type_begin < key && type_max_size > key)
  {
   ptr_func pFun = s_array[key];
   if (pFun) 
    (this->*pFun)(val);
  }
 }
 // 使用map 映射
 int operator[] (int key)
 {
  map<type_func,ptr_func>::iterator it =  s_map.find((type_func)key);
  if (it != s_map.end())
  {
   ptr_func pFun = it->second;
   if (pFun)  return (this->*pFun)(false);
  }
  return NULL;
 }
 // 使用數(shù)組 映射
 int operator() (int key,bool val)
 {
  if (type_begin < key && type_max_size > key)
  {
   ptr_func pFun = s_array[key];
   if (pFun)  return (this->*pFun)(val);
  }
  return NULL;
 }
};
map<type_func, CAnimal::ptr_func> CAnimal::s_map;     
CAnimal::ptr_func     CAnimal::s_array[type_max_size];
//////////////////////////////////////////////////////////////////////////
// 非成員函數(shù)
void func_eat(int = 0) { }
void func_run(int = 0) { }
void func_walk(int =0) { }
void func_cry(int = 0) { }
typedef void (*ptrFun)(int);
map<type_func,ptrFun> g_map;
ptrFun     g_array[type_max_size];
int _tmain(int argc, _TCHAR* argv[])
{
 //////////////////////////////////////////////////////////////////////////
 // 為了便于說(shuō)明,下面代碼不做安全檢查
 // 非成員函數(shù)映射2種用法
 // init
 g_map[type_eat] = func_eat;
 g_map[type_run] = func_run;
 g_map[type_walk] = func_walk;
 g_map[type_cry] = func_cry;
 g_array[type_eat] = func_eat;
 g_array[type_run] = func_run;
 g_array[type_walk] = func_walk;
 g_array[type_cry] = func_cry;
 // using
 g_map[type_eat](1);
 g_map[type_run](2);
 g_map[type_walk](3);
 g_map[type_cry](4);
 g_array[type_eat](1);
 g_array[type_run](2);
 g_array[type_walk](3);
 g_array[type_cry](4);
 //////////////////////////////////////////////////////////////////////////
 // 成員函數(shù)映射使用
 CAnimal Dog;
 Dog.Process(type_eat);
 Dog.ProcessByUseMap(type_run,true);
 Dog.ProcessByUseArray(type_cry,false);
 Dog[type_walk];
 Dog(type_sleep,true);
 Dog(type_run,false);
 return 1;
}

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 香蕉视频三级 | 国产99久久精品一区二区永久免费 | 91精品国产91久久久久久最新 | 欧美影视一区二区三区 | 日本福利一区二区 | 狼人狠狠干 | 91中文在线 | 一性一交一色生活片 | 欧美一级高清免费 | 日本成人| 日b片| 九色在线| 美女在线一区 | 国产视频三区 | 欧美激情亚洲 | 欧美一区二区三区精品 | 久久国产精品久久久久久久久久 | 91在线精品视频观看 | 日韩无在线 | 亚洲三区在线观看 | 黄色成人在线视频 | 亚洲欧洲精品一区二区 | 亚洲日韩中文字幕在线播放 | 日日干夜夜干 | 看免费5xxaaa毛片 | 欧美国产日韩精品 | 中文字幕亚洲综合 | 国产韩国精品一区二区三区 | 日本久久综合 | 国产精品一区二区三区四区 | 一级黄色国产视频 | 不卡黄色片| 欧美在线一区二区 | 播放毛片 | 精品少妇一区二区三区日产乱码 | 国内精品视频在线观看 | 亚洲美女久久 | 超碰中文字幕 | 久草福利资源 | 午夜视频网站 | 国产成人精品电影 |