c++實現字符串類的封裝

MyString.h文件

    #define  _CRT_SECURE_NO_WARNINGS#pragma once#include<iostream>#include<string>using namespace std;class MyString{friend ostream & operator<<(ostream & cout, MyString & str);friend istream & operator>>(istream &cin, MyString & str);public:MyString(const char *);MyString(const MyString & str);~MyString();//重載等號運算符MyString & operator=(const char *str);MyString & operator=(const MyString & str);//重載[]運算符char & operator[](int index);//重載+運算符MyString  operator+( char *str);MyString  operator+( MyString & str);//重載 == 運算符bool operator ==(const char * str);bool operator==(const MyString & str);private:char * pString;//執行堆區指針int m_Size; //字符串大小};

MyString.cpp文件

    #define  _CRT_SECURE_NO_WARNINGS#include"MyString.h"//左移運算符重載ostream & operator<<(ostream & cout, MyString & str){cout << str.pString;return cout;}//右移運算符istream & operator>>(istream &cin, MyString & str){//先判斷 原始是否有內容if (str.pString != NULL){delete[]str.pString;str.pString = NULL;}//讓用戶輸入內容char buf[1024];cin >> buf;//把用戶輸入的字符串 賦值給strstr.pString = new char[strlen(buf) + 1];strcpy(str.pString, buf);str.m_Size = strlen(buf);return cin;}MyString::MyString(const char * str){printf("有參構造調用\n");this->pString = new char[strlen(str) + 1];strcpy(this->pString, str);this->m_Size = strlen(str);}MyString::MyString(const MyString & str){printf("拷貝構造調用\n");this->pString = new char[strlen(str.pString) + 1];strcpy(this->pString, str.pString);this->m_Size = str.m_Size;}MyString::~MyString(){//printf("析構調用\n");if (this->pString != NULL){delete[]this->pString;this->pString = NULL;}}MyString& MyString::operator=(const char *str){if (this->pString != NULL){delete[]this->pString;this->pString = NULL;}this->pString = new char[strlen(str)+1];strcpy(this->pString, str);return *this;}MyString& MyString::operator=(const MyString & str){if (this->pString != NULL){delete[]this->pString;this->pString = NULL;}this->pString = new char[strlen(str.pString) + 1];strcpy(this->pString, str.pString);return *this;}char & MyString::operator[](int index){return this->pString[index];}MyString MyString::operator+(const char * str){//計算返回的字符串開辟的大小int newSize = this->m_Size + strlen(str) + 1;char * tmp = new char[newSize];memset(tmp, 0, newSize);//拼接字符串strcat(tmp, this->pString);strcat(tmp, str);MyString newStr(tmp);delete[]tmp;return newStr;}MyString MyString::operator+(const MyString & str){//計算返回的字符串開辟的大小int newSize = this->m_Size + strlen(str.pString) + 1;char * tmp = new char[newSize];memset(tmp, 0, newSize);//拼接字符串strcat(tmp, this->pString);strcat(tmp, str.pString);MyString newStr(tmp);delete[]tmp;return newStr;}bool MyString:: operator ==(const char * str){if (str == NULL){return false;}if (strcmp(this->pString, str) == 0 && this->m_Size == strlen(str)){return true;}return false;}bool MyString::operator==(const MyString & str){if (&str == NULL){return false;}if (strcmp(this->pString, str.pString) == 0 && this->m_Size == strlen(str.pString)){return true;}return false;}

測試文件

    #include"MyString.h"	    void test01(){MyString str = "abc";cout << str << endl;/*cout << "請輸入str新的內容" << endl;cin >> str;cout << "新內容為" << str<<endl;*/MyString str2(str);MyString str3 = "aaaaaaaaa";str3 = str2;str3 = "aaaa";cout << "str3=" << str3 << endl;str3[0] = 'w';cout << "str3第一個位置為" << str3[0] << endl;MyString str4 = " ";//str4 = str2 +str3;//字符串拼接cout << "str4為" << str4 << endl;if (str3 == str4){cout << "str3與str4相等" << endl;}else{cout << "str3與str4不相等" << endl;}}int main(){test01();system("pause");return 0;}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/383311.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/383311.shtml
英文地址,請注明出處:http://en.pswp.cn/news/383311.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

c++中的繼承--1(引出,繼承方式,繼承的對象模型)

繼承的引出 概念&#xff1a; 繼承(inheritance)機制是面向對象程序設計使代碼可以復用的最重要的手段&#xff0c;它允許程序員在保持原有類特 性的基礎上進行擴展&#xff0c;增加功能&#xff0c;這樣產生新的類&#xff0c;稱派生類。繼承呈現了面向對象程序設計的層次結構…

Makefile經典教程(掌握這些足夠)

makefile很重要 什么是makefile&#xff1f;或許很多Winodws的程序員都不知道這個東西&#xff0c;因為那些Windows的IDE都為你做了這個工作&#xff0c;但我覺得要作一個好的和professional的程序員&#xff0c;makefile還是要懂。這就好像現在有這么多的HTML的編輯器&#xf…

c++中的繼承--2(繼承中的析構函數和構造函數,繼承中同名成員,繼承中靜態成員)

繼承中的構造函數和析構函數 繼承中的構造和析構順序 子類創建對象時&#xff0c;先調用父類的構造&#xff0c;然后調用自身構造析構順序與構造順序相反子類不會繼承父類的構造函數和析構函數如果父類中沒有合適默認構造&#xff0c;那么子類可以利用初始化列表的方式顯示的…

Linux鎖機制和線程安全

鎖機制是多線程編程中最常用的同步機制&#xff0c;用來對多線程間共享的臨界區進行保護。 1. 互斥鎖&#xff1a;pthread_mutex&#xff0c;屬于sleep-waiting類型的鎖 pthread_mutex_t *mutex; int pthread_mutex_int(mutex, attr) //以動態方式創建互斥鎖&#xff0c;參…

c++中的繼承--3(多繼承問題,菱形繼承)

繼承中的多繼承 #include<iostream>using namespace std;class Base1 { public:Base1(){m_A 10;} public:int m_A;};class Base2 { public:Base2(){m_A 10;} public:int m_B;int m_A;};class Son :public Base1, public Base2 {public:int m_C;int m_D; };void test01…

c++中的多態---1(多態概念,靜態聯編和動態聯編,多態原理解析,重載,重寫,重定義的對比)

多態的基本概念 多態是面向對象設計語言數據抽象和繼承之外的第三個基本特征多態性(polymorphism)提供接口與具體實現之間的另一層隔膜&#xff0c;從而將“what”和“how”分離開來&#xff0c;多態性改善了代碼的可讀和組織性&#xff0c;同時也使創建的程序具有可擴展性&am…

Ubuntu下各種服務搭建及操作技巧

Ubuntu下搭建TFTP 1、安裝軟件包 sudo apt-get install tftpd tftp xinetd 2、建立配置文件 在/etc/xinetd.d/下建立一個配置文件tftp sudo vi /etc/xinetd.d/tftp 內容如下 service tftp { socket_type dgram protocol udp wait yes user root …

c++多態--2(計算器,純虛函數和抽象類)

為什么要用多態 早期方法不利于擴展開閉原則 開閉原則 對擴展開放 對修改關閉利用多態實現—利于后期擴展&#xff0c;結構性非常好&#xff0c;可讀性高&#xff0c;效率稍微低&#xff0c;發生多態內部結構復雜 多態成立的條件 又繼承 子類重寫父類虛函數的函數&#xff1…

使用Automake和Autoconf生成Makefile

automake 所產生的 Makefile 除了可以做到程序的自動編譯和鏈接 外&#xff0c;還可以用來生成各種文檔&#xff08;如manual page、info文件&#xff09;&#xff0c;可以將源代碼文件包裝起來以供發布。所以程序源代碼所存放的目錄 結構最好符合GNU的標準慣例。下面以hello.…

c++中多態---3(虛析構和純虛析構,向上類型轉化和向下類型轉化)

虛析構和純虛析構 虛析構virtual ~類名(){}類內聲明&#xff0c;類內實現解決問題&#xff1a;通過父類指針指向子類對象釋放時候不干凈的問題 純虛析構 寫法 virtual ~類名(){}0; 類內聲明 類外實現 如果出現了純虛析構函數&#xff0c;這個類也算是抽象類&#xff0c;不可…

嵌入式開發硬件知識札記

三態邏輯 1. 概念 三態指其輸出既可以是一般二值邏輯電路&#xff0c;即正常的高電平&#xff08;邏輯1&#xff09;或低電平&#xff08;邏輯0&#xff09;&#xff0c;又可以保持特有的高阻抗狀態。高阻態相當于隔斷狀態&#xff08;電阻很大&#xff0c;相當于開路&#xff…

《凡人修仙傳》中打斗場景(c++多態實現)

我們 要實現打斗場景&#xff0c;第一&#xff0c;我們需要有打斗的雙方&#xff0c;一個是英雄&#xff0c;一個是怪物&#xff0c;他們都有自己的屬性&#xff0c;比如攻擊&#xff0c;防御&#xff0c;血量。其次我們的英雄還會有武器。武器上有一些加成屬性&#xff0c;可以…

使用mp4v2將aac音頻h264視頻數據封裝成mp4開發心得

這陣子在搗鼓一個將游戲視頻打包成本地可播放文件的模塊。開始使用avi作為容器&#xff0c;弄了半天無奈avi對aac的支持實在有限&#xff0c;在播放時音視頻時無法完美同步。 關于這點avi文檔中有提到&#xff1a; For AAC, one RAW AAC frame usually spans over 1024 samples…

c++模板---1(模板概念,利用模板實現數組排序,函數模板調用規則)

什么叫泛型編程&#xff1f;1. 參數類型化。 2. 模板 模板概念 c提供了函數模板&#xff0c;所謂函數模板&#xff0c;實際上是建立一個通用函數&#xff0c;其函數類型和形參類型不具體制定&#xff0c;用一個虛擬的類型來代表。這個通用函數就成為函數模板。凡是函數體相同…

c++模板--2(模板機制,模板的局限性,類模板,類模板做函數的參數)

函數模板機制結論 編譯器并不是把函數模板處理成能狗處理任何類型的函數函數模板通過具體類型產生不同的函數編譯器會對函數模板進行兩次編譯&#xff0c;在聲明的地方對模板代碼的本身進行編譯&#xff0c;在調用的地方對參數替換后代碼進行編譯在編譯器編譯階段&#xff0c;…

arm-linux 交叉編譯 mp4v2

2014-09-23 14:44 1901人閱讀 評論(0) 收藏 舉報 版權聲明&#xff1a;本文為博主原創文章&#xff0c;未經博主允許不得轉載。 1、下載mp4v2的源代碼&#xff08;http://code.google.com/p/mp4v2/downloads/list&#xff09;mp4v2-2.0.0.tar.bz2 2. 進入相應目錄 ./configu…

c++模板---3(類模板碰到繼承問題,類模板類外實現,類模板與友元函數)

類模板碰到繼承問題 基類如果是模板類&#xff0c;必須讓子類告訴編譯器 基類中的T到底是什么類型 如果不告訴&#xff0c;那么無法分配內存&#xff0c;編譯不過 利用參數列表class Child :public Base<int> #include<iostream>using namespace std;template&l…

Linux USB札記

嵌入式linux內核添加USB模塊&#xff08;U盤&#xff09;支持 使用menuconfig工具進行配置 1、Device Drivers->SCSI device support->SCSI disk support此選項必須勾選 2、Device Drivers->USB support->Support for Host-side USB 此選項選中后會出現子菜單&…

c++實現任意類型數組類的封裝

MyArray.hpp #pragma once #include<iostream> #include<string> using namespace std; template<class T>class MyArray { public://構造explicit MyArray(int capacity) //防止隱式類型轉換&#xff0c;防止MyArray arr 10{this->m_Capacity capacity…

Linux內核配置選項 (經典學習)

轉載地址http://book.csdn.net/bookfiles/972/10097230254.shtml 2.5 Linux內核配置選項 下面以最新的Linux 2.6.20內核為例&#xff0c;介紹比較常用的一些Linux內核配置選項&#xff0c;其他選項讀者可以參考系統提供的幫助信息。 需要說明的是&#xff0c;在內核配置中&am…