欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解C++ 編寫String 的構(gòu)造函數(shù)、拷貝構(gòu)造函數(shù)、析構(gòu)函數(shù)和賦值函數(shù)

 更新時間:2017年08月28日 09:38:56   作者:愛思考的小鳥  
這篇文章主要介紹了詳解C++ 編寫String 的構(gòu)造函數(shù)、拷貝構(gòu)造函數(shù)、析構(gòu)函數(shù)和賦值函數(shù)的相關(guān)資料,這里提供實例幫助大家理解掌握這部分內(nèi)容,需要的朋友可以參考下

詳解C++ 編寫String 的構(gòu)造函數(shù)、拷貝構(gòu)造函數(shù)、析構(gòu)函數(shù)和賦值函數(shù)

 編寫類String 的構(gòu)造函數(shù)、析構(gòu)函數(shù)和賦值函數(shù),已知類String 的原型為:

class String
{
public:
String(const char *str = NULL); // 普通構(gòu)造函數(shù)
String(const String &other); // 拷貝構(gòu)造函數(shù)
~ String(void); // 析構(gòu)函數(shù)
String & operate =(const String &other); // 賦值函數(shù)
private:
char *m_data; // 用于保存字符串
}; 

#include <iostream> 
class String 
{ 
public: 
  String(const char *str=NULL);//普通構(gòu)造函數(shù) 
  String(const String &str);//拷貝構(gòu)造函數(shù) 
  String & operator =(const String &str);//賦值函數(shù) 
  ~String();//析構(gòu)函數(shù) 
protected: 
private: 
  char* m_data;//用于保存字符串 
}; 
 
//普通構(gòu)造函數(shù) 
String::String(const char *str)
{ 
  if (str==NULL)
  { 
    m_data=new char[1]; //對空字符串自動申請存放結(jié)束標志'\0'的空間 
    if (m_data==NULL)
    {//內(nèi)存是否申請成功 
     std::cout<<"申請內(nèi)存失敗!"<<std::endl; 
     exit(1); 
    } 
    m_data[0]='\0'; 
  } 
  else
  { 
    int length=strlen(str); 
    m_data=new char[length+1]; 
    if (m_data==NULL)
    {//內(nèi)存是否申請成功 
      std::cout<<"申請內(nèi)存失敗!"<<std::endl; 
      exit(1); 
    } 
    strcpy(m_data,str); 
  } 
} 

//拷貝構(gòu)造函數(shù) 
String::String(const String &other)
{ //輸入?yún)?shù)為const型 
  int length=strlen(other.m_data); 
  m_data=new char[length+1]; 
  if (m_data==NULL)
  {//內(nèi)存是否申請成功 
    std::cout<<"申請內(nèi)存失敗!"<<std::endl; 
    exit(1); 
  } 
  strcpy(m_data,other.m_data); 
} 

//賦值函數(shù) 
String& String::operator =(const String &other)
{//輸入?yún)?shù)為const型 
  if (this == &other) //檢查自賦值 
  { return *this; }

  delete [] m_data;//釋放原來的內(nèi)存資源 

  int length=strlen(other.m_data);   
  m_data= new char[length+1]; 
  if (m_data==NULL)
  {//內(nèi)存是否申請成功 
    std::cout<<"申請內(nèi)存失敗!"<<std::endl; 
    exit(1); 
  } 
  strcpy(m_data,other.m_data); 

  return *this;//返回本對象的引用 
} 

//析構(gòu)函數(shù) 
String::~String()
{ 
  delete [] m_data; 
} 
 
void main()
{ 
  String a; 
  String b("abc"); 
  system("pause"); 
} 

以上就是C++ 編寫String 的構(gòu)造函數(shù)、拷貝構(gòu)造函數(shù)、析構(gòu)函數(shù)和賦值函數(shù)的實例,如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關(guān)文章

  • C++計算整數(shù)序列的最長遞增子序列的長度操作

    C++計算整數(shù)序列的最長遞增子序列的長度操作

    這篇文章主要介紹了C++計算整數(shù)序列的最長遞增子序列的長度操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • 實例講解C++編程中的虛函數(shù)與虛基類

    實例講解C++編程中的虛函數(shù)與虛基類

    這篇文章主要介紹了C++編程中的虛函數(shù)與虛基類的實例講解,虛函數(shù)與虛基類的使用是C++入門學習中的基礎(chǔ)知識,需要的朋友可以參考下
    2016-02-02
  • C++深入分析回顧函數(shù)重載

    C++深入分析回顧函數(shù)重載

    C++ 允許多個函數(shù)擁有相同的名字,只要它們的參數(shù)列表不同就可以,這就是函數(shù)的重載(Function Overloading),借助重載,一個函數(shù)名可以有多種用途
    2022-06-06
  • C語言完整實現(xiàn)12種排序算法(小結(jié))

    C語言完整實現(xiàn)12種排序算法(小結(jié))

    本文主要介紹了C語言完整實現(xiàn)12種排序算法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-05-05
  • 深入理解C++中變量的存儲類別和屬性

    深入理解C++中變量的存儲類別和屬性

    這篇文章主要介紹了C++中變量的存儲類別和屬性,是C++入門學習中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-09-09
  • 深入探究C/C++中互斥量(鎖)的實現(xiàn)原理

    深入探究C/C++中互斥量(鎖)的實現(xiàn)原理

    ? 互斥量是一種同步原語,用于保護多個線程同時訪問共享數(shù)據(jù),互斥量提供獨占的、非遞歸的所有權(quán)語義,本文將和大家一起深入探究C/C++中互斥量(鎖)的實現(xiàn)原理,感興趣的小伙伴跟著小編一起來看看吧
    2024-06-06
  • 從C++單例模式到線程安全詳解

    從C++單例模式到線程安全詳解

    下面小編就為大家?guī)硪黄獜腃++單例模式到線程安全詳解。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-12-12
  • C++和java設(shè)計模式之單例模式

    C++和java設(shè)計模式之單例模式

    這篇文章主要為大家詳細介紹了C++和java設(shè)計模式之單例模式的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • C++?Boost?Lambda表達式詳解

    C++?Boost?Lambda表達式詳解

    Lambda?表達式(lambda?expression)是一個匿名函數(shù),Lambda表達式基于數(shù)學中的λ演算得名。本文就來為大家詳細講講C++中Lambda表達式的使用,需要的可以參考一下
    2022-11-11
  • C++實現(xiàn)LeetCode(120.三角形)

    C++實現(xiàn)LeetCode(120.三角形)

    這篇文章主要介紹了C++實現(xiàn)LeetCode(120.三角形),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-07-07

最新評論