>
Home

登龙(DLonng)

选择大于努力

实现自己的 my_string


版权声明:本文为 DLonng 原创文章,可以随意转载,但必须在明确位置注明出处!

my_string.h

我们经常在 C++ 中使用 std::string 类型,我们应该了解这个类型的基本实现原理,帮助我们更好的理解 C++ 的语法。下面是一段简单的 std::string 的基本简单实现,有兴趣的可以自己实践下。

#ifndef _MY_STRING_H
#define _MY_STRING_H

#include <iostream>
#include <utility>
#include <assert.h>
#include <string.h>

namespace MyStringSpaceOne {

/*
 * A string for write-on-paper in an interview.
 */
class String 
{
public:
	/* 默认构造函数 */
	String() : data(new char[1])
	{
		std::cout << "()" << std::endl;
		*data = '\0';
	}
	/* 带有字符串指针的构造函数 */
	String(const char* str) : data(new char[strlen(str) + 1])
	{
		std::cout << "(*)" << std::endl;
		strcpy(data, str);		
	}
	/* copy 构造函数 */
	String(const String& rhs) : data(new char[rhs.size() + 1])
	{
		std::cout << "(&)" << std::endl;
		strcpy(data, rhs.c_str());
	}
	
	/* noexcept : this fun don`t throw exception */
	~String() noexcept
	{
		std::cout << "(~)" << std::endl;
		delete [] data;
	}
	
	/* 赋值操作符 */
	String& operator=(String rhs)
	{
		std::cout << "(=)" << std::endl;
		swap(rhs);
		return *this;
	}
	
	/* C++11 移动构造函数 */
	String(String&& rhs) noexcept : data(rhs.data)
	{
		std::cout << "(move)" << std::endl;
		rhs.data = nullptr;
	}
	
	/* 获取 string 的长度 */
	size_t size() const 
	{
		return strlen(data);
	}
	
	/* 获取 string 的 C 字符串 */
	const char* c_str() const
	{
		return data;
	}
	
	/* 给移动构造函数调用的 swap 函数 */
	void swap(String& rhs)
	{
		std::cout << "swap" << std::endl;
		std::swap(data, rhs.data);
	}


private:
	/* 存储字符串的指针 */
	char *data;

};

};

#endif //MY_STRING_H

my_string.cpp

#include <iostream>

#include "my_string.h"


void print_string(const MyStringSpaceOne::String& str)
{
	if (nullptr == str.c_str())
	{
		std::cout << "c_str: nullptr" << std::endl;
		std::cout << "length: 0" << std::endl;
	}
	else 
	{
		std::cout << "c_str: "  << str.c_str() << std::endl;
		std::cout << "length: " << str.size()  << std::endl;
	}

	std::cout << std::endl;
}



int main(void)
{
	const char pstr[] = "hello world";
	
	// 调用默认构造函数
	MyStringSpaceOne::String s1;	
	print_string(s1);
	
	// 调用带有字符串指针的构造函数
	MyStringSpaceOne::String s2(pstr);
	print_string(s2);

	//调用 copy 构造函数
	MyStringSpaceOne::String s3(s2);	
	print_string(s3);

	// 调用赋值操作符
	MyStringSpaceOne::String s4;
	s4 = s2;	
	print_string(s4);

	// 调用移动构造函数
	MyStringSpaceOne::String s5 = std::move(s4);	
	print_string(s5);
	print_string(s4);

	return 0;
}

使用下面的命令编译运行:

gcc my_string.cpp -std=c++11
./a.out

运行结果:

()
c_str: 
length: 0

(*)
c_str: hello world
length: 11

(&)
c_str: hello world
length: 11

()
(&)
(=)
swap
(~)
c_str: hello world
length: 11

(move)
c_str: hello world
length: 11

c_str: nullptr
length: 0

(~)
(~)
(~)
(~)
(~)

DLonng at 05/09/17