亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

C++高質量編程點滴

2019-11-17 05:17:52
字體:
來源:轉載
供稿:網友

  一、你需要一個函數將一個數組賦值為等差數列,并將會在函數的外部使用它?! ?

  不合理: 

  int *GetArray( int n )
  {
   int *p = new int[n];
   for ( int i = 0; i < n; i++ )
   {
    p[i] = i;
   }
   return p;
  } 

  合理: 

  void GetArray( int *p, int n )
  {
   for ( int i = 0; i < n; i++ )
   {
   p[i] = i;
   }
  } 
  解析:  

  檢查內存泄露的最好辦法,就是檢查完全配對的申請和釋放,在函數中申請而在外部釋放,將導致代碼的一致性變差,難以維護。而且,你寫的函數不一定是你自己使用的,這樣的函數別人會不知道該怎么適當的使用,假如它是一個DLL的導出函數,并且你在不同的平臺下使用了,便會導致系統崩潰。最好的解決辦法就是在函數調用的外面將內存申請好,函數只對數據進行復制?! ?

  二、你需要寫一個類來為你治理一個指針,這個類將封裝對指針的申請內存、釋放和其它一些基本操作?!?

  不合理: 

  class A
  {
  public:
   A( void ) {}
   ~A( void ) { delete []m_PPTr; }
   void Create( int n ){ m_pPtr = new int[n]; }
  PRivate:
   int *m_pPtr;
  }; 
  合理:  

  class A
  {
  public:
   A( void ) : m_pPtr(0){}
   ~A( void ) { Clear(); }
   bool Create( int n ){ if ( m_pPtr ) return false; m_pPtr = new int[n]; return ture; }
   void Clear( void ) { delete []m_pPtr; m_pPtr = 0; }
  private:
   int *m_pPtr;
  };
  解析:  

  不合理的代碼就在于當你重復調用Create的時候就會造成內存泄露,解決的辦法就是在new之前判定一下指針是否為0。要能夠有效的執行這個判定,則必須在構造的時候對指針進行初始化,并為這個類添加一個Clear函數來釋放內存。  
  
  三、接上題的Create函數,你現在需要根據傳入的參數做一些比較復雜的算法操作,并對申請的數組賦值。  

  不合理: 

  bool Create(int *a, int n )
  {
   if ( m_pPtr )
   return false;
   m_pPtr = new int[n];
   for ( int i = 0; i < n; i++ )
   {
   m_pPtr[i] = 3 / a[i];
   }
   return true;
  }
  合理:  

  template
  class auto_array  
  {
  public:
   eXPlicit auto_array(_Ty *pPtr=0)throw():m_Ptr(pPtr){}
   ~auto_array(){delete[]m_Ptr;}
   void reset(_Ty *pPtr=0){if(pPtr!=m_Ptr){delete[]m_Ptr;m_Ptr=pPtr;}}
   _Ty* release(void){_Ty *pTemp=m_Ptr;m_Ptr=0;return pTemp;}
  private:
   auto_array(const auto_array&other){}
   auto_array& Operator=(const auto_array& other){}
   _Ty *m_Ptr;
  };
  bool A::Create(int *a, int n )
  {
   if ( m_pPtr )
   return false;
   auto_array PtrGuard( new int[n] );
   for ( int i = 0; i < n; i++ )
   {
   if ( 0 == a[i] )
   {
   return false;
   }
   PtrGuard .get()[i] = 3 / a[i];
   }
   m_pPtr = PtrGuard.release();
   return true;
  }
  解析:  

  在循環中,當參數數組a中的某一個值為0時,將會產生除0異常,那么,這將會導致你在上面為m_pPtr申請的內存不能合理的釋放。為了解決這個問題,我們寫了一個auto_array作為衛兵來看管企圖逃逸的指針。在auto_array對象PtrGuard析構的時候它會同時刪除附加在它身上的內存指針。我們首先用PtrGuard來進行所有的指針操作,在確定操作完全結束的最后,把指針再賦給真正的變量,并使PtrGuard放棄對該指針的附加,這樣我們就得到了一個最安全的結果。另外需要注重的是,C++的STL庫里本來有一個和auto_array功能非常相似的模版類auto_ptr,但是它只支持單個對象的內存,不支持數組,寫這樣一個auto_array也是不得已而為之。

  四、你需要開辟一段內存來存放和治理一個4 x 4的矩陣,并單位化之。

  不合理:


  int aMatrix[4][4];
  for ( int i = 0; i < 4; i++ )
  {
   for ( int j = 0; j < 4; j++ )
   {
   if ( i == j )
   {
   aMatrix[i][j] = 1;
   }
   else
   {
   aMatrix [i][j] = 0;
   }
   }
  } 
  合理:

  int aMatrix[4 * 4];
  for ( int i = 0; i < 4; i++ )
  {
   for ( int j = 0; j < 4; j++ )
   {
   if ( i == j ) 
   {
   aMatrix[ i * 4 + j ] = 1;
   }
   else
   {
   aMatrix [ i * 4 + j ] = 0;
   }
   }
  }  
  解析: 

  在任何時候都要避免使用多維數組,數組維數的增加,相應的程序復雜度將會以幾何級數的方式增加,也更加的難于理解?! ?

  五、你需要對上面那個矩陣賦值,使它從左上角向右下角按先縱后橫的順序給它賦值

  不合理:

  for( int i = 0; i < 4; i++ )
  {
   for ( int j = 0; j < 4; j++ )
   {
   aMatrix[ j * 4 + i ] = i * 4 + j;
   }
  }  
  合理:

  for( int i = 0; i < 4; i++ )
  {
   for ( int j = 0; j < 4; j++ )
   {
   aMatrix[i * 4 + j ] = j * 4 + i;
   }
  }
  解析:  

  盡量保證順序的訪問數組的每一個元素。由于Windows內存的治理模式,內存是分頁治理的。順序訪問數組可以基本保證頁面不會往返切換,從而減少了頁失效的數量,提高了程序的整體性能。這種性能的提升對于大的數組尤為明顯?! ?

  六、你需要用3個float值來表示一個三維的點,并要寫一個函數對一個三維點的數組進行計算賦值?!?

  不合理:

  void foo( float *pPoints[3] )
  {
   float aPoint[3] = { 1.0f, 2.0f, 3.0f };
   int nCount = (int)_msize( pPoints );
   for ( int i = 0; i < nCount; i++ )
   {
   pPoints[i][0] = aPoint[0];
   pPoints[i][1] = aPoint[1];
   pPoints[i][2] = aPoint[2];
   }
  }
  合理:

  strUCt POINT3
  {
   float x, y, z;
  };
  void foo( POINT3 *pPoints, int nCount )
  {
   POINT3 Pt = { 1.0f, 2.0f, 3.0f };
   for ( int i = 0; i < nCount; i++ )
   {
   pPoints[i] = Pt;

   }
  }
  解析:  

  有兩點,一,不要使用_msize對數組的大小進行測定,_msize只能對使用malloc或calloc申請的內存進行大小測定,對于其它的如new或一些API,將會導致程序的崩潰。在設計此類需要傳入數組的函數時,別忘了把數組的元素數量也做為參數一并傳入,哪怕它是固定的,這將是一個良好的習慣。二,對于float[3]這種類型,盡量避免直接使用它,最好的辦法就是用struct對其進行簡單的封裝,在復制的時候直接使用“=”就可以進行準確的按位賦值了。

  七、你有一個函數的定義,在這個函數中會new一個比較大的對象Data,并在計算后將它刪除。但這個函數將被頻繁調用?! ?

  不合理:  

  void foo( void )
  {
   Data *p = new Data;
   CalcData( p );
   delete p;
  }  
  合理:

  char Buf[sizeof(DATA)];
  void foo( void )
  {
   Data *p = new(Buf) Data;
   CalcData( p );
  } 
  解析:  

  new(buf) type;是定位的new語法,它不會真正的分配內存,而是簡單的在指定的已分配的內存起點上劃分出一段與類型大小匹配的空間,并直接在這段內存上對該類型進行構造對象,并返回對象的指針。由于它沒有真正的分配內存空間,因此它的效率是非常高的,在類似于上述例程中,頻繁申請和釋放一個大對象的操作,定位的new可以帶來很大的效率提升。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久艳片www.17c.com| 亚洲精品日韩久久久| 欧美激情综合亚洲一二区| 久久久精品欧美| 亚洲欧美国产制服动漫| 国产精品视频永久免费播放| 国产成人啪精品视频免费网| 欧美性xxxx极品hd欧美风情| 日韩大片免费观看视频播放| 欧美另类极品videosbest最新版本| 亚洲国模精品一区| 亚洲成人av在线播放| 国产精品视频1区| 欧美一级黑人aaaaaaa做受| 91午夜在线播放| 国产视频精品自拍| 久久精品久久久久久国产 免费| 国产精品日韩在线播放| 日韩黄色高清视频| 韩国v欧美v日本v亚洲| 国产精品视频男人的天堂| 美女久久久久久久| 成人av在线亚洲| 欧美裸体xxxxx| 91久久久久久久久久久| 国产成人欧美在线观看| 久久成人免费视频| 在线观看国产精品91| 亚洲精品mp4| 国产v综合ⅴ日韩v欧美大片| 日韩精品在线电影| 精品电影在线观看| 欧美另类精品xxxx孕妇| 久久久久久久久久久免费| 国产综合福利在线| 国产女精品视频网站免费| 国产精品久久久久久久午夜| 国产视频久久久久| 91免费看国产| 精品无人区乱码1区2区3区在线| 欧美性受xxx| 色yeye香蕉凹凸一区二区av| 日韩电影第一页| 97视频免费在线看| 国产99久久精品一区二区永久免费| 亚洲国产99精品国自产| 97色在线观看免费视频| 欧美久久久精品| 欧美在线亚洲一区| 欧美成人午夜视频| 亚洲娇小xxxx欧美娇小| 亚洲国产天堂久久综合网| 夜夜嗨av色综合久久久综合网| 日韩一区二区福利| 中文字幕亚洲精品| 日韩精品中文字幕久久臀| 91av在线视频观看| 777777777亚洲妇女| 亚洲综合日韩中文字幕v在线| 狠狠操狠狠色综合网| www.日韩视频| 久久99久久久久久久噜噜| 538国产精品一区二区免费视频| 日韩免费在线观看视频| 久久手机免费视频| www.日韩av.com| 91欧美精品成人综合在线观看| 欧美精品在线免费播放| 欧美日韩精品国产| 狠狠久久亚洲欧美专区| 国产一区二区精品丝袜| 国产日韩视频在线观看| 国产精品一区二区三区在线播放| 在线观看日韩专区| 成人激情视频在线播放| 欧美亚洲另类制服自拍| 欧美孕妇孕交黑巨大网站| 亚洲免费av网址| 九九热这里只有在线精品视| 亚洲国产欧美精品| 日韩动漫免费观看电视剧高清| 亚洲香蕉av在线一区二区三区| 亚洲免费视频一区二区| 69av视频在线播放| 欧美疯狂做受xxxx高潮| 日韩在线视频导航| 国内精品小视频| 亚洲美女av在线| 韩国19禁主播vip福利视频| www.日韩视频| 日韩在线免费观看视频| 中文字幕日韩欧美精品在线观看| 久久久免费精品视频| 国产精品igao视频| 青青草成人在线| 欧美性猛交xxxx免费看久久久| 久久伊人精品一区二区三区| 91美女片黄在线观看游戏| 国产精品三级网站| www国产精品视频| 亚洲视频综合网| 日韩美女视频中文字幕| 国产91ⅴ在线精品免费观看| 欧美黄色三级网站| 精品五月天久久| 久久久亚洲精选| 久久久99免费视频| 国产精品69久久久久| 久久人人爽人人爽爽久久| 久久亚洲私人国产精品va| 国产精品日韩在线观看| 中文亚洲视频在线| 欧美激情在线视频二区| 国产精品美女免费视频| 自拍偷拍亚洲在线| 日韩在线观看免费全| 高清一区二区三区日本久| 成人免费视频xnxx.com| 国产精品亚洲аv天堂网| 国产精品高清网站| 日韩在线视频中文字幕| 欧美精品xxx| 久久香蕉精品香蕉| 色偷偷av亚洲男人的天堂| 国产精品网站入口| 国产精欧美一区二区三区| 精品视频在线播放色网色视频| 精品国偷自产在线视频99| 精品视频在线播放免| 欧美午夜女人视频在线| 色av中文字幕一区| 色天天综合狠狠色| 亚洲精品之草原avav久久| 国产成人中文字幕| 欧美重口另类videos人妖| 免费不卡欧美自拍视频| 在线精品国产成人综合| 欧美一二三视频| 青青久久aⅴ北条麻妃| 亚洲最大福利视频网| 在线播放国产一区中文字幕剧情欧美| 狠狠躁夜夜躁人人爽天天天天97| 日韩电影中文 亚洲精品乱码| 2019中文字幕在线观看| 18久久久久久| 午夜精品久久久久久久男人的天堂| 91视频国产一区| 久久亚洲国产成人| 中文字幕在线观看日韩| 国内精久久久久久久久久人| 亚洲一区中文字幕在线观看| 欧洲成人午夜免费大片| 国产欧美精品日韩精品| 国外成人性视频| 亚洲人成电影网站| 欧美亚洲国产精品| 国产精品自拍偷拍| 精品国产户外野外| 国产一区红桃视频| 日韩一级裸体免费视频| 欧美在线一区二区三区四| 国产精品91在线| 亚洲美女性生活视频| 97久久超碰福利国产精品…|