C++运算符重载(二)之左移运算符重载

简介: 左移运算符重载作用:可以输出自定义数据类型1.利用成员函数实现左移运算符class Person {public: Person(int a, int b) { this->m_A = a; this->m_B = b; } //利用成员函数实现左移运算符:p.operator<<(cout)简化版本p << cout 无法实现cout在左边。 //成员函数 p << p 不是我们想要的效果,想要cout<<p

左移运算符重载

作用:可以输出自定义数据类型

1.利用成员函数实现左移运算符

classPerson {

public:

   Person(inta, intb)

   {

       this->m_A=a;

       this->m_B=b;

   }

   //利用成员函数实现左移运算符:p.operator<<(cout)简化版本p << cout 无法实现cout在左边。

   //成员函数 p << p 不是我们想要的效果,想要cout<<p

   voidoperator<<(Person&p){

       cout<<"a:"<<p.m_A<<" b:"<<p.m_B;

   }

private:

   intm_A;

   intm_B;

};

voidtest() {

   Personp1(10, 20);

   p1<<p1;//p1.operator<<(p1);

}

intmain() {

   test();

   system("pause");

   return0;

}

上代码使用成员函数重载左移运算符的局限:成员函数 p << p 不是我们想要的效果,想要cout<<p

网络异常,图片无法展示
|

2.利用全局函数实现左移重载

classPerson {

   //全局函数做友元,告诉编译器 operator<<全局函数 是 Person类的好朋友,可以访问类中的私有内容

   friendvoidoperator<<(ostream&out, Person&p);

public:

   Person(inta, intb)

   {

       this->m_A=a;

       this->m_B=b;

   }

private:

   intm_A;

   intm_B;

};

//只能全局函数实现左移重载

//ostream对象只能有一个

voidoperator<<(ostream&out, Person&p) {

   out<<"a:"<<p.m_A<<" b:"<<p.m_B;

}

voidtest() {

   Personp1(10, 20);

   cout<<p1;

}

intmain() {

   test();

   system("pause");

   return0;

}

上面的代码的局限性:输出结果无换行,若改为cout<<p<<endl;会报错,因为链式不成立,cout<<p是一个函数的调用,返回值是void,需要返回cout类型才能与endl;形成链式编程思想。

优化:

classPerson {

   friendostream&operator<<(ostream&out, Person&p);

public:

   Person(inta, intb)

   {

       this->m_A=a;

       this->m_B=b;

   }

private:

   intm_A;

   intm_B;

};

//只能全局函数实现左移重载

//ostream对象只能有一个,所以添加&取地址,cout的定义类型为ostream

ostream&operator<<(ostream&out, Person&p) {

   out<<"a:"<<p.m_A<<" b:"<<p.m_B;

   returnout;//返回cout需要更改函数头为ostream

}

voidtest() {

   Personp1(10, 20);

   cout<<p1<<"hello world"<<endl; //链式编程。

}

intmain() {

   test();

   system("pause");

   return0;

}

PS:ostream& operator<<(ostream& out, Person& p){};此处的Person& p是否使用&对本程序没有影响,使用&指将p1传入,而不加&指拷贝构造一份p1后传入,不管是拷贝还是p1还是拷贝后的p1都打印的p1的内容。

总结:重载左移运算符配合友元可以实现输出自定义数据类型

目录
相关文章
|
21天前
|
存储 编译器 C++
【c++】类和对象(下)(取地址运算符重载、深究构造函数、类型转换、static修饰成员、友元、内部类、匿名对象)
本文介绍了C++中类和对象的高级特性,包括取地址运算符重载、构造函数的初始化列表、类型转换、static修饰成员、友元、内部类及匿名对象等内容。文章详细解释了每个概念的使用方法和注意事项,帮助读者深入了解C++面向对象编程的核心机制。
54 5
|
3月前
|
C++
C++(十九)new/delete 重载
本文介绍了C++中`operator new/delete`重载的使用方法,并通过示例代码展示了如何自定义内存分配与释放的行为。重载`new`和`delete`可以实现内存的精细控制,而`new[]`和`delete[]`则用于处理数组的内存管理。不当使用可能导致内存泄漏或错误释放。
|
3月前
|
C++
C++(十五) 运算符重载
C++中的运算符重载允许对已有运算符的功能进行重新定义,从而扩展语言功能、简化代码并提升效率。重载遵循特定语法,如 `friend 类名 operator 运算符(参数)`。重载时需注意不可新增或改变运算符数量、语义、优先级、结合性和返回类型。常见示例包括双目运算符 `+=` 和单目运算符 `-` 及 `++`。输入输出流运算符 `&lt;&lt;` 和 `&gt;&gt;` 也可重载。部分运算符只能作为成员函数重载。
|
5月前
|
NoSQL 编译器 Redis
c++开发redis module问题之如果Redis加载了多个C++编写的模块,并且它们都重载了operator new,会有什么影响
c++开发redis module问题之如果Redis加载了多个C++编写的模块,并且它们都重载了operator new,会有什么影响
|
5月前
|
存储 C++
【C++】string类的使用③(非成员函数重载Non-member function overloads)
这篇文章探讨了C++中`std::string`的`replace`和`swap`函数以及非成员函数重载。`replace`提供了多种方式替换字符串中的部分内容,包括使用字符串、子串、字符、字符数组和填充字符。`swap`函数用于交换两个`string`对象的内容,成员函数版本效率更高。非成员函数重载包括`operator+`实现字符串连接,关系运算符(如`==`, `&lt;`等)用于比较字符串,以及`swap`非成员函数。此外,还介绍了`getline`函数,用于按指定分隔符从输入流中读取字符串。文章强调了非成员函数在特定情况下的作用,并给出了多个示例代码。
|
5月前
|
NoSQL Redis C++
c++开发redis module问题之避免多个C++模块之间因重载operator new而产生的冲突,如何解决
c++开发redis module问题之避免多个C++模块之间因重载operator new而产生的冲突,如何解决
|
5月前
|
自然语言处理 程序员 C++
C++基础知识(五:运算符重载)
运算符重载是C++中的一项强大特性,它允许程序员为自定义类型(如类或结构体)重新定义标准运算符的行为,使得这些运算符能够适用于自定义类型的操作。这样做可以增强代码的可读性和表达力,使得代码更接近自然语言,同时保持了面向对象编程的封装性。
|
5月前
|
Java 程序员 C++
|
5月前
|
编译器 C++
【C++】详解运算符重载,赋值运算符重载,++运算符重载
【C++】详解运算符重载,赋值运算符重载,++运算符重载
|
6月前
|
编译器 C++
【C++】类和对象③(类的默认成员函数:赋值运算符重载)
在C++中,运算符重载允许为用户定义的类型扩展运算符功能,但不能创建新运算符如`operator@`。重载的运算符必须至少有一个类类型参数,且不能改变内置类型运算符的含义。`.*::sizeof?`不可重载。赋值运算符`=`通常作为成员函数重载,确保封装性,如`Date`类的`operator==`。赋值运算符应返回引用并检查自我赋值。当未显式重载时,编译器提供默认实现,但这可能不足以处理资源管理。拷贝构造和赋值运算符在对象复制中有不同用途,需根据类需求定制实现。正确实现它们对避免数据错误和内存问题至关重要。接下来将探讨更多操作符重载和默认成员函数。