日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Cpp / std::string 实现

發(fā)布時間:2024/10/14 编程问答 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Cpp / std::string 实现 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

一、答案

#include <iostream> #include <string.h> #include <assert.h>class String { public:String(const char *str = nullptr);String(const String &other);~String(void);String &operator=(const String &other);bool operator==(const String &str);char *Stringcpy(char *dst, const char *src);friend std::ostream &operator<<(std::ostream &o, const String &str);private:char *m_data; };String::String(const char *str) {if (str == nullptr){m_data = new char[1];*m_data = '\0';}else{int len = strlen(str);m_data = new char[len + 1];Stringcpy(m_data, str);} } String::~String(void) {delete[] m_data; }String::String(const String &other) {int len = strlen(other.m_data);m_data = new char[len + 1];Stringcpy(m_data, other.m_data); } char *String::Stringcpy(char *dst, const char *src) {assert(dst != nullptr);assert(src != nullptr);char *ret = dst;while ((*dst++ = *src++) != '\0');return ret; } String &String::operator=(const String &other) {if (this == &other)return *this;String tmp(other);char *p = tmp.m_data;tmp.m_data = m_data;m_data = p;return *this; }bool String::operator==(const String &str) {return strcmp(m_data, str.m_data) == 0; }std::ostream &operator<<(std::ostream &o, const String &str) {o << str.m_data;return o; }int main() {String s = "hello";String s2 = s;String ss = "hello";std::cout << "s = " << s << std::endl;std::cout << "s2 = " << s2 << std::endl;std::cout << std::boolalpha << (ss == s) << std::endl;return 0; }

二、其他

這里面有個考點,就是賦值構造函數(shù)的寫法。傳統(tǒng)的寫法可能如下:

String &String::operator=(const String &other) {if (this == &other)return *this;delete[] m_data;int len = strlen(other.m_data);m_data = new char[len + 1];Stringcpy(m_data, other.m_data);return *this; }

這種寫法能夠很好的完成功能,但是問題在于如果 new char 時如果系統(tǒng)內(nèi)容不足的話就會拋出異常,此時因為上一句代碼已經(jīng)將 m_data 釋放掉了,所以此時的 String 實例就是異常的。就算外面已經(jīng)做好異常處理,String 實例已經(jīng)是不能再用的了。

解決這個問題的方案可以是將 new char 放置到 delete 的前面,這樣就算拋出了異常也不會造成 String 實例的異常。

另外一種方案就是上面答案中的方法,巧妙的是不僅可以解決上述問題,還可以通過臨時變量退出當前上下文時自動釋放內(nèi)存的方式釋放掉之前的字符串。

?

參考:https://blog.csdn.net/qq_31558353/article/details/50788843

?

(SAW:Game Over!)

?

總結

以上是生活随笔為你收集整理的Cpp / std::string 实现的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。