首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

像“>>,<<”这样的运算符重载不起作用

是因为它们是位移运算符,而不是可重载的运算符。位移运算符用于对二进制位进行移动操作,而不是对对象进行操作。因此,无法通过运算符重载来改变它们的行为。

位移运算符包括左移运算符(<<)和右移运算符(>>)。左移运算符将二进制位向左移动指定的位数,右移运算符将二进制位向右移动指定的位数。这些运算符通常用于处理二进制数据、位操作和底层系统编程。

在C++中,运算符重载是一种特性,允许用户重新定义已有的运算符的行为,使其适用于自定义的数据类型。但是,并不是所有的运算符都可以被重载,只有一部分运算符可以被重载,而位移运算符不在其中。

如果需要对自定义的数据类型进行位移操作,可以通过定义成员函数或全局函数来实现。例如,可以定义一个成员函数来实现对象的位移操作:

代码语言:txt
复制
class MyClass {
public:
    MyClass operator<<(int n) {
        // 实现左移操作
        // ...
        return *this;
    }

    MyClass operator>>(int n) {
        // 实现右移操作
        // ...
        return *this;
    }
};

通过定义这样的成员函数,可以在自定义的数据类型上使用位移运算符,例如:

代码语言:txt
复制
MyClass obj;
obj << 3;  // 调用 operator<< 函数,实现左移操作
obj >> 2;  // 调用 operator>> 函数,实现右移操作

需要注意的是,这种方式只适用于自定义的数据类型,对于内置的基本数据类型(如整数、浮点数等),位移运算符的行为是固定的,无法改变。

总结起来,像“>>,<<”这样的位移运算符不支持运算符重载,无法改变其行为。如果需要在自定义的数据类型上实现位移操作,可以通过定义成员函数来实现。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

《挑战30天C++入门极限》C++运算符重载转换运算符

当一个类含有转换运算符重载函数的时候,有时候会破坏C++原有规则,导致运算效率降低,这一点不得不注意。   示例如下: //例3 //程序作者:管宁 //站点:www.cndev-lab.com //所有稿件均有版权,如要转载,请务必著名出处和作者 #include <iostream> using namespace std; class Test { public: Test(int a = 0) { cout<<this<<":"<<"载入构造函数!"<<a<<endl; Test::a = a; } Test(Test &temp) { cout<<"载入拷贝构造函数!"<<endl; Test::a = temp.a; } ~Test() { cout<<this<<":"<<"载入析构函数!"<<this->a<<endl; cin.get(); } operator int()//转换运算符,去掉则不会调用 { cout<<this<<":"<<"载入转换运算符函数的内存地址:"<<this->a<<endl; return Test::a; } public: int a; }; int main() { Test b=Test(99);//注意这里 cout<<"b的内存地址"<<&b<<endl; cout<<b.a<<endl; system("pause"); }   按照C++对无名对象的约定,Test b=Test(99);C++是会按照Test b(99);来处理的,可是由于转换运算符的加入,导致这一规律被破坏,系统会“错误的”认为你是要给对象赋值,所以系统首先利用Test(99)创建一个临时对象用于赋值过程使用,可是恰恰系统又没有使用自动提供的赋值运算重载函数去处理,因为发现b对象并未构造,转而又不得不将开始原本用于赋值而创建的临时对象再次的强转换为int类型,提供给b对象进行构造,可见中间的创建临时对象和载入转换运算符函数的过程完全是多余,读者对此例要认真解读,充分理解。   运行结果如下图所示(运行过程的解释见图):

02
领券