zoukankan      html  css  js  c++  java
  • 第十八章 38总结 简单

    // 38总结
    #include <iostream>
    using namespace std;
    class String
    {
    public:
    	String(); //默认的构造函数
    	~String(){ delete []str; len=0; cout<<"析构函数执行"<<endl; }
    	String(const char*const ch); //构造带值的string
    	
    	int getlen()const { return len;}   //读取长度
    	//const char *getstr()const{ return str;} //读取字符串
    
    	//重载输出函数
    	friend ostream&operator<<(ostream &o, const String &s)
    	{
    		o<<s.str;
    		return o;
    	}
        
    	friend istream&operator>>(istream &i, String &s)
    	{
    		 i>>s.str;
    	     return i;
    	}
    	//当运算符重载函数定义为成员函数时,二元运算符只带一个参数
    	//将这个函数定义为友元函数即可
    	friend bool operator<(const String&str1, const String&str2)
    	{
    		if(strcmp(str1.str, str2.str) < 0){
    		    return 1;
    		}else
    			return 0;
    	}
    	friend bool operator>(const String&str1, const String&str2)
    	{
    		if(strcmp(str1.str, str2.str) > 0){
    		    return 1;
    		}else
    			return 0;
    	}
    	friend bool operator==(const String&str1, const String&str2)
    	{
    		if(strcmp(str1.str, str2.str) == 0){
    		    return 1;
    		}else
    			return 0;
    	}
    
    
    	//这里是可以修改的
    	char &operator[](unsigned short int  length);
    	char  operator[](unsigned short int  length)const;
    
    	//复制构造函数
    	String (const String&r);
    
    	//重载赋值运算符=
    	String &operator=(const String &s);
    
    	String operator+(const String&s); //重载相加运算符
    	void operator+=(const String&s); //重载相加运算符
    	
    
    private:
    	String(unsigned short int); //构造带值的string
    	unsigned short int len;
    	char *str;
    };
    //创建一个空的str变量
    String::String()
    {
        len = 0;
    	str = new char[1];
    	str[0] = '\0';
    };
    String::String(const char*const ch)
    {
    	cout<<"带一个参数的构造函数"<<endl;
    	len = strlen(ch);
    	str = new char[len+1];
    	for(int i=0; i<len; i++){
    	   str[i] = ch[i];
    	}
    	str[len] = '\0';
    };
    
    
    String::String(unsigned short int lenght)
    {
    	cout<<"带一个int参数的构造函数"<<endl;
    	len = lenght;
    	str = new char[len+1];
    	for(int i=0; i<=len; i++){
    	   str[i] = '\0';
    	}
    };
    
    char & String::operator[](unsigned short int length)
    {
    	    if(length > len){
    		   return str[len-1]; //返回可见字符的值
    		}else{
    		   return str[length];
    		}
    };
    
    char String::operator[](unsigned short int length)const
    {
    	    cout<<"下标运算符const执行"<<endl;
    		if(length > len){
    		   return str[len-1]; //返回可见字符的值
    		}else{
    		   return str[length];
    		}
    };
    
    String::String (const String&rs)
    {
    	len = rs.getlen();
    	str = new char[len+1];
    	for(int i=0; i<len; i++){
    	    str[i] = rs[i]; 
    		//这里因为我们构造一个新对象并且用旧对象来为它赋值,很明显,不会修改旧对象的值,所以旧对象rs在调用operator[]const函数的时候,不用将指定字符串的地址返回,只需要要按值返回这个字符即可
    		//第二次重载的operator[]运算符函数,按值返回的一个字符,同时在函数体前面加了一个const
    		//表示该函数可以操作const对象,也就是rs
    		//这样由于2个同名的函数,它的类型不同,一个可操作const对象,一个不可以,这样就可以做到了对函数的重载
    	}
    	str[len]='\0';
    	cout<<"复制构造函数完成:"<<str<<endl;
    
    };
    
    String& String::operator=(const String &s)
    {
    	cout<<"operator=执行"<<endl;
    	if(this == &s)
    	{
    	    return *this;
    	}else{
    	    delete []str; //删除左边的字符串
    		len = s.getlen();
    		str = new char[len+1];
    		for(int i=0; i<len; i++){
    		    str[i] = s[i];
    		}
    		str[len] = '\0';
    	}
    	return *this; //注意按引用返回,也就是别名
    }
    
    String String::operator+(const String &s)
    {
    	cout<<"operator+执行......"<<endl;
    	int total = len + s.getlen();
    	String temp(total);
    	int i, j;
    	for(i=0; i<len; i++){
    	     temp[i] = str[i];
    	}
    	for(j=0; j<s.getlen(); j++, i++){
    	    temp[i] = s[j];
    	}
    	return temp;
    }
    
    
    
    void String::operator+=(const String&s)
    {
    	cout<<"这里执行的是相+=运算符"<<endl;
    	int total = len + s.getlen();
    	String temp(total);
    	int i, j;
    	for(i=0; i<len; i++){
    	    temp[i] = str[i];
    	}
    	for(j=0; j<s.getlen(); j++,i++){
    	    temp[i] = s[j];
    	}
    	*this = temp;
    }
    
    
    int main()
    {
    	//1 可对字符串进行初始化
    	String s1 = "hello wordl";
    	//2 可计算字符串的长度
    	cout<<"s1字符串长度:"<<s1.getlen()<<endl;
    	//3 可对字符串进行赋值操作
    	String s2;
    	s2 = s1;
    	//4 重载了字符串的输出
    	cout<<s1<<s2<<endl;
    
    	//5 通过重载输入字符串,输入字符串
    	//cin>>s1>>s2;
    	//cout<<s1<<s2<<endl;
    
    	//6 可将char字符串赋值给String
    	char ch[11] = "not at all";
    	s1 = ch;
    	cout<<s1<<endl;
    
    	//7 可向构造对象那样构造字符串
    	String s3;
    	String s4("mother");
    
    	//8 可用下标运算符来操作字符串
    	cout<<s4<<endl;
    	cout<<s4[0]<<endl;
    
    	//9 可以比较
    	s1 > s2;
    
    	//10 两个对象可以相加
    	s1="aaa";
    	s2="bbb";
    	s3 = s1 + s2;
    	cout<<"s3:"<<s3<<endl;
    
    	//12可以进行+=操作
    	s1 += s2;
    	cout<<"s1:"<<s1<<endl;
    	String s5("a");
    	s1 = s5;
    	cout<<"s1:"<<s1<<endl;
    	
    	return 0;
    }
    

      

  • 相关阅读:
    springboot 集成RabbitMQ
    服务接口API限流 Rate Limit 续
    服务接口API限流 Rate Limit
    聊下并发和Tomcat线程数
    java 线程池 异步任务
    Tomcat中更改网站根目录和默认页的配置方法
    QPS从0到4000请求每秒,谈达达后台架构演化之路
    分布式与集群是什么 ? 区别是什么?
    大型网站技术架构演变总结
    提升高并发量服务器性能解决思路
  • 原文地址:https://www.cnblogs.com/xiangxiaodong/p/2700773.html
Copyright © 2011-2022 走看看