String类运算符重载,自己实现
body, table{font-family: 微软雅黑; font-size: 10pt}
table{border-collapse: collapse; border: solid gray; border-width: 2px 0 2px 0;}
th{border: 1px solid gray; padding: 4px; background-color: #DDD;}
td{border: 1px solid gray; padding: 4px;}
tr:nth-child(2n){background-color: #f8f8f8;}
|
#include <iostream>
#include<stdlib.h>
#include<stdio.h>
#include<sstream>
#include<string.h>
using namespace std;
class String
{
private:
char *pstr_;
public:
String();
String(const char *);
String(const String&);
~String();
String & operator = (const String &);
String & operator = (const char *);
String & operator += (const String &);
String & operator += (const char *);
char & operator [] (std::size_t index);
const char & operator [](std::size_t index)const;
std::size_t size() const;
const char* c_str() const;
friend bool operator == (const String &,const String &);
friend bool operator != (const String &,const String &);
friend bool operator < (const String &,const String &);
friend bool operator > (const String &,const String &);
friend bool operator <= (const String &,const String &);
friend bool operator >= (const String &,const String &);
friend std::ostream & operator << (std::ostream & os,const String &s);
friend std::istream & operator >> (std::istream & is,String & s);
};
String operator + (const String &,const String &);
String operator + (const String &,const char *);
String operator + (const char *,const String &);
String::String()
{
cout<<"String()"<<endl;
pstr_=new char[1];
strcpy(pstr_,"");
}
String::~String()
{
cout<<"~String()"<<endl;
delete []pstr_;
}
String::String(const char *str)
{
cout<<"String(const char *)"<<endl;
pstr_=new char[strlen(str)+1];
strcpy(pstr_,str);
}
String :: String(const String & s)
{
cout<<"String(const String &)"<<endl;
pstr_=new char[strlen(s.pstr_)+1];
strcpy(pstr_,s.pstr_);
}
String & String::operator = (const String & s)
{
cout<<"String & operator =(const String &)"<<endl;
this->~String();
pstr_=new char[strlen(s.pstr_)+1];
strcpy(pstr_,s.pstr_);
return *this;
}
String & String::operator =(const char *s)
{
cout<<"String & operator=(const char *)"<<endl;
this->~String();
pstr_=new char[strlen(s)+1];
strcpy(pstr_,s);
return *this;
}
String & String::operator +=(const String &s)
{
cout<<"String & operator += (const String &)"<<endl;
int len1=strlen(this->pstr_);
int len2=strlen(s.pstr_);
char *a=(char*)calloc(len1,sizeof(char));
strcpy(a,this->pstr_);
this->~String();
this->pstr_=new char[len1+len2+1];
sprintf(this->pstr_,"%s%s",a,s.pstr_);
return *this;
}
String & String::operator += (const char *s)
{
cout<<"String & operator += (const char *)"<<endl;
int len1=strlen(this->pstr_);
int len2=strlen(s);
char *a=(char*)calloc(len1,sizeof(char));
strcpy(a,this->pstr_);
this->~String();
this->pstr_=new char[len1+len2+1];
sprintf(this->pstr_,"%s%s",a,s);
return *this;
}
std::ostream & operator<<(std::ostream & os,const String &s)
{
cout<<"std::ostream & operator << (std::ostream & ,const String &)"<<endl;
os<<s.pstr_;
return os;
}
char& String::operator[] (std::size_t index)
{
cout<<"char & operator[] (std:: size_t index)"<<endl;
int len=strlen(this->pstr_);
char *a=(char*)calloc(len,sizeof(char));
strcpy(a,pstr_);
return a[index];
}
|
const char& String::operator[](std::size_t index)const
{
cout<<"const char & operator[] (std:: size_t index)const"<<endl;
int len=strlen(this->pstr_+1); //这里错了,this->pstr_+1相当于指正偏移到下一个字符
char *a=(char*)calloc(len,sizeof(char));
strcpy(a,pstr_);
return a[index];
}
std::size_t String::size()const
{
cout<<"std::size_t size()const"<<endl;
int len=strlen(this->pstr_);
return len;
}
const char* String::c_str() const
{
cout<<"const char* c_str() const"<<endl;
int len=strlen(this->pstr_+1);
char *a=(char*)calloc(len,sizeof(char));
//这里不管申请多大的空间,后面拷贝函数如果不够他都会自动在申请空间所以结果没出现错误
strcpy(a,pstr_);
return a;
}
bool operator == (const String & a1,const String &a2)
{
cout<<"bool operator == (const String &,const String &)"<<endl;
if((strcmp(a1.c_str(),a2.c_str()))==0)
return 1;
return 0;
}
bool operator != (const String & a1,const String & a2)
{
cout<<"bool operator != (const String &,const String &)"<<endl;
if((strcmp(a1.c_str(),a2.c_str()))!=0)
return 1;
return 0;
}
bool operator < (const String &a1,const String &a2)
{
cout<<"bool operator < (const String &,const String &)"<<endl;
if((strcmp(a1.c_str(),a2.c_str()))<0)
return 1;
return 0;
}
bool operator > (const String &a1,const String &a2)
{
cout<<"bool operator > (const String &,const String &)"<<endl;
if((strcmp(a1.c_str(),a2.c_str()))>0)
return 1;
return 0;
}
bool operator <= (const String &a1,const String &a2)
{
cout<<"bool operator <= (const String &,const String &)"<<endl;
if((strcmp(a1.c_str(),a2.c_str()))<0)
return 1;
else if((strcmp(a1.c_str(),a2.c_str()))==0)
return 1;
return 0;
}
bool operator >= (const String &a1,const String &a2)
{
cout<<"bool operator >= (const String &,const String &)"<<endl;
if((strcmp(a1.c_str(),a2.c_str()))>0)
return 1;
else if((strcmp(a1.c_str(),a2.c_str()))==0)
return 1;
return 0;
}
std::istream & operator >> (std::istream & is,String &s)
{
cout<<"std::istream & operator >> (std::istream &m,String &)"<<endl;
is>>s.pstr_;
return is;
}
String operator + (const String &a1,const String &a2)
{
cout<<"String operator + (const String &,const String &)"<<endl;
String tmp=a1;
tmp+=a2;
return tmp;
}
String operator + (const String &a1,const char * a2)
{
cout<<"String operator + (const String &,const char *)"<<endl;
String tmp=a1;
tmp+=a2;
return tmp;
}
String operator + (const char *a1,const String & a2)
{
cout<<"String operator + (const char *,const String &)"<<endl;
String tmp;
tmp+=a1;
tmp+=a2;
return tmp;
}
//测试代码
int main()
{
String s;
String s1("hello");
String s2(s1);
String s3="world";
s1=s2;
String s4;
s4="wangdao";
s+=s3;
s4+="nihao";
cout<<s4<<endl;
cout<<s4[2]<<endl;
cout<<s4.size()<<endl;
cout<<s4.c_str()<<endl;
bool bool1=(s1>s4);
cout<<bool1<<endl;
bool bool2=(s1>=s3);
cout<<bool2<<endl;
cin>>s;
cout<<s<<endl;
String s5=s1+s2;
cout<<s5<<endl;
String s6=s1+"shenzhen";
cout<<s6<<endl;
String s7="shenzhen1"+s1;
cout<<s7<<endl;
return 0;
}
|
String类运算符重载,自己实现的更多相关文章
- c++类运算符重载遇到的函数形参问题
class A { public: A(int arg1, int arg2); ~A(); A &operator = ( A &other); A operator + ( A & ...
- 从零开始学C++之运算符重载(三):完善String类([]、 +、 += 运算符重载)、>>和<<运算符重载
在前面文章中使用过几次String类的例子,现在多重载几个运算符,更加完善一下,并且重载流类运算符. []运算符重载 +运算符重载 +=运算符重载 <<运算符重载 >>运算符重 ...
- 完善String类([]、 +、 += 运算符重载)、>>和<<运算符重载
在前面文章中使用过几次String类的例子,现在多重载几个运算符,更加完善一下,并且重载流类运算符. []运算符重载 +运算符重载 +=运算符重载 <<运算符重载 >>运算符重 ...
- 04737_C++程序设计_第9章_运算符重载及流类库
例9.1 完整实现str类的例子. #define _CRT_SECURE_NO_WARNINGS #include <iostream> #include <string> ...
- 【C++札记】实现C++的string类
C++有了string类使得操作字符串变得很方便.有关string类,面试过程中也经常问到的就是自己实现一个sring类.下边实现个String类供大家参考: String.h #pragma onc ...
- 深入C++05:运算符重载
运算符重载 1.复数类 运算符重载目的:使对象运算表现得和编译器内置类型一样: 复数类例子 #include<iostream> using namespace std; class CC ...
- C++:String类
String类 1.使用String类必须在程序的开始包括头文件string,即要有如下语句:#include<string> 2.string类字符串对象的使用方法与其他对象一样stri ...
- C++中的运算符重载练习题
1.RMB类 要求: 定义一个RMB类 Money,包含元.角.分三个数据成员,友元函数重载运算符‘+’(加) 和 ‘-’(减),实现货币的加减运算 例如: 请输入元.角 分: ...
- 包装类、基本数据类型及String类之间的相互转换
包装类:8种基本数据类型对应一个类,此类即为包装类 一.基本数据类型 包装类 及String之间的转换 1.基本数据类型转化为包装类:调用包装类的构造器 int i=10; Inte ...
随机推荐
- 【android】开源一个企业通讯录app
软件背景:该app不是替代手机通讯录,而是对其一种补充.项目只是通讯录客户端,数据源是访问本地.还是访问远程服务器,由你来实现 开源地址:http://git.oschina.net/yso/Smar ...
- Spring MVC 复习笔记03
1. @RequestMapping 1). url映射 定义controller方法对应的url,进行处理器映射使用. 2). 窄化请求映射 3). 限制http请求方法 出于安全性考虑,对htt ...
- NetBeans 启动时出现 Invalid jdkhome specified提示
执行 NetBeans 出现如下文字内容: Invalid jdkhome specifiedCannot locate java installation in specifired jdkhome ...
- python将一些朋友的姓名存储在一个列表中,访问该列表中的每个元素,从而将每个朋友的姓名都打印出来
""" 3-1 姓名: 将一些朋友的姓名存储在一个列表中,并将其命名为 names . 依次访问该列表中的每个元素,从而将每个朋友的姓名都打印出来. "&quo ...
- Android事件处理下(按键、触摸屏和滚动球的一些实现细节)
http://www.cnblogs.com/andtt/articles/2145563.html 对于按键事件,调用mDevices[i]->layoutMap->map进行映射.映射 ...
- SQL执行并返回执行前/后结果
SQLServer: 1.插入数据,并返回插入的数据: INSERT INTO TestTB(Province,City) output inserted.Province, inserted.Cit ...
- 20145103《JAVA程序设计》课程总结
每周读书笔记链接汇总 假期笔记 http://www.cnblogs.com/20145103fwh/p/5248170.html 第一周读书笔记 http://www.cnblogs.com/201 ...
- 【读书笔记】《深入浅出nodejs》第五章 内存控制
海量请求+长时间运行 -> 内存控制 -> 一切资源高效循环利用 1. V8的垃圾回收机制与内存限制 在Node中通过JavaScript使用内存时,只能使用部分内存(64位系统下约1.4 ...
- Job流程:决定map个数的因素
此文紧接Job流程:提交MR-Job过程.上一篇分析可以看出,MR-Job提交过程的核心代码在于 JobSubmitter 类的 submitJobInternal()方法.本文就由此方法的这一句代码 ...
- Keepalived安装配置入门
准备两台虚拟机,IP如下: A:192.168.1.11 B:192.168.1.12 A为Master,B为BackUp 1.安装 yum install keepalived -y 2.配置 A服 ...