0

0

C# 运算符重载方法 C#如何对运算符进行重载

月夜之吻

月夜之吻

发布时间:2026-02-06 10:51:02

|

882人浏览过

|

来源于php中文网

原创

C#中可重载运算符包括一元的+、-、!、~、++、--、true、false,二元的+、-、*、/、%、&、|、^、、==、!=、、=,且==与!=等须成对重载;不可重载&&、||、?:、=等。

c# 运算符重载方法 c#如何对运算符进行重载

运算符重载在 C# 中只能在 structclass 内部用 public static 方法实现,且必须使用 operator 关键字声明;不能重载所有运算符,也不能改变运算符优先级或结合性。

哪些运算符可以重载

C# 允许重载的运算符有明确限制。可重载的包括:

  • 一元运算符:+-!~++--truefalse
  • 二元运算符:+-*/%&|^>>==!=>>=
  • 必须成对重载:==!=>>=truefalse

不可重载的包括:&&||?:=.?:->sizeoftypeofnewcheckedunchecked 等。

重载 ==!= 的正确写法

这是最容易出错的地方:重载 == 后,编译器会强制要求同时重载 !=,并且还必须重写 Equals(object)GetHashCode(),否则会触发 CS0660 / CS0661 警告。

典型错误是只重载 ==,或在 == 中直接调用 object.ReferenceEquals 但没处理 null 参数。

public class Vector2
{
    public double X { get; }
    public double Y { get; }
public Vector2(double x, double y) => (X, Y) = (x, y);

public static bool operator ==(Vector2 a, Vector2 b)
{
    if (ReferenceEquals(a, b)) return true;
    if (a is null || b is null) return false;
    return a.X == b.X && a.Y == b.Y;
}

public static bool operator !=(Vector2 a, Vector2 b) => !(a == b);

public override bool Equals(object obj) => obj is Vector2 v && this == v;

public override int GetHashCode() => HashCode.Combine(X, Y);

}

GAIPPT
GAIPPT

AI PPT制作和美化神器

下载

重载 + 运算符并支持混合类型

如果希望 Vector2 + double 也能工作,不能只写 Vector2 + Vector2;需额外提供参数类型不同的重载版本。但要注意隐式转换可能引发歧义。

  • 推荐显式提供 Vector2 + doubledouble + Vector2 两个版本(后者因交换律必要)
  • 避免定义 implicit operator double(Vector2),否则 vector + 1.0 可能被误解释为 (double)vector + 1.0
  • 返回新实例而非修改原对象(符合值语义直觉)
public static Vector2 operator +(Vector2 a, Vector2 b) =>
    new Vector2(a.X + b.X, a.Y + b.Y);

public static Vector2 operator +(Vector2 v, double s) => new Vector2(v.X + s, v.Y + s);

public static Vector2 operator +(double s, Vector2 v) => new Vector2(v.X + s, v.Y + s);

为什么重载 ++ 要返回新对象而不是 this

因为 ++ 是一元后缀/前缀运算符,C# 要求其返回值参与表达式计算。若返回 this 并修改内部状态,会导致与内置数值类型行为不一致(如 int++ 返回副本),也破坏不可变设计意图。

更关键的是:如果 ++ 修改自身又返回 this,则 v1 = v2++; 会让 v1v2 引用同一对象,后续修改 v2 会意外影响 v1 —— 这在结构体中还会因装箱引发更隐蔽问题。

所以标准做法是:

  • 前缀 ++:创建新实例,返回新实例
  • 后缀 ++:先保存当前状态,再创建新实例,返回保存的旧状态
public static Vector2 operator ++(Vector2 v) => new Vector2(v.X + 1, v.Y + 1);

// 后缀版本需手动模拟(C# 不自动区分,靠方法签名) public static Vector2 operator ++(ref Vector2 v) { var old = v; v = new Vector2(v.X + 1, v.Y + 1); return old; }

注意:C# 实际不支持 ref 形参用于运算符重载(上述写法非法),真正合规的后缀 ++ 必须返回旧值副本,且不能修改原对象 —— 所以多数场景下应避免重载 ++,改用明确的 Increment() 方法。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

240

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

600

2024.03.01

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1513

2023.10.24

Go语言中的运算符有哪些
Go语言中的运算符有哪些

Go语言中的运算符有:1、加法运算符;2、减法运算符;3、乘法运算符;4、除法运算符;5、取余运算符;6、比较运算符;7、位运算符;8、按位与运算符;9、按位或运算符;10、按位异或运算符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

235

2024.02.23

php三元运算符用法
php三元运算符用法

本专题整合了php三元运算符相关教程,阅读专题下面的文章了解更多详细内容。

127

2025.10.17

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

282

2025.06.09

golang结构体方法
golang结构体方法

本专题整合了golang结构体相关内容,请阅读专题下面的文章了解更多。

194

2025.07.04

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

606

2023.08.02

Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

2

2026.02.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 8.7万人学习

C 教程
C 教程

共75课时 | 4.5万人学习

C++教程
C++教程

共115课时 | 16.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号