- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
对于数学包,我正在尝试为不同类型的矩阵创建类,例如典型的矩形矩阵、三角矩阵、对角矩阵等。原因自然是为了节省特殊矩阵的高效存储和高效算法实现。但我仍然希望拥有重载运算符的灵 active ,其中 C = A + B 将 A 和 B 作为任何类型的矩阵并返回相应的结果(如果其中一个操作数是矩形,则结果可以降级为典型的矩形矩阵) .
我想到了 2 个可能的想法,这两个想法都很乱:
(1) 一个 IMatrix 接口(interface),它会列出每种矩阵需要实现的所有方法,例如转置、逆等,每种矩阵的高效实现是不同的。这里有两个问题: (a) 运算符重载是静态方法,因此不能在接口(interface)中列出,甚至不能在实现接口(interface)的基类中列出。运算符重载必须在每个类中单独编写,如果不在客户端代码中进行困惑的类型检查和强制转换,我不可能实现 C=A+B 类型的操作(正如我上面提到的),我真的很想避免. (b) 当我定义运算符重载时,我不能将两个操作数都作为接口(interface):即我不能在 DiagonalMatrix 类中执行以下操作:
public override IMatrix operator +(IMAtrix lhsMatrix, IMatrix rhsMatrix)
{ ... }
(2) 可以有一个 Matrix 类,类中存储一个矩阵类型的变量(可以是一个 Enum)。根据类型,我们可以实现数据结构和算法。然后运算符重载将无缝地工作。这里的一个问题是:(a) 该类可能会很大,可能带有用于在启动特定算法之前检查矩阵类型的 switch-case 语法。对于每个二元运算符,我必须有 n^2 个案例,n 是我要实现的矩阵类型的数量。也可能是一场维护噩梦。
看起来,如果没有运算符重载细节,我本可以使用 Factory pattern或 Visitor pattern ,但操作重载并非如此。解决这个问题的最佳方法是什么?
目前我找到的资源:
编辑:
2011 年 4 月 25 日:添加了迄今为止我发现的有关此问题的更多资源。
最佳答案
如果这是我的项目,我会采用 #1 的变体:定义一个抽象 Matrix
类,它由更具体的类型(如 TriangularMatrix
)继承。这将允许您创建运算符(即使所述运算符只是抛出 NotImplementedException),然后您可以在派生类中覆盖这些运算符。它还将允许您将任何矩阵作为矩阵处理,并具有一组通用的功能。
您唯一会丢失的是编译器检查您是否确实覆盖了方法和运算符;由于运算符是静态的,因此不能将它们抽象化。如果您希望让基类中的运算符简单地调用可以在基类中抽象的等效命名方法(例如,+ 将调用 Add 方法),从而强制子类实现它,则可以解决此问题。
数学问题:可以将三角矩阵加到矩形矩阵上,还是两个加数的类型和/或维数必须匹配?如果是前者,请考虑在 Matrix 基类中实现运算符,并让该运算符实现一个策略模式,调用可以对每种类型组合执行实际操作的内部类。如果是后者,只需覆盖该类型矩阵的有效运算符的基类实现即可。
关于c# - 关于继承和运算符重载的 OOP 设计问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5019683/
Or 运算符 对两个表达式进行逻辑“或”运算。 result = expression1 Or expression2 参数 result 任意数值变量。 expression1 任意
Not 运算符 对表达式执行逻辑非运算。 result = Not expression 参数 result 任意数值变量。 expression 任意表达式。 说明 下表显示如何
Is 运算符 比较两个对象引用变量。 result = object1 Is object2 参数 result 任意数值变量。 object1 任意对象名。 object2 任意
\ 运算符 两个数相除并返回以整数形式表示的结果。 result = number1\number2 参数 result 任意数值变量。 number1 任意数值表达式。 numbe
And 运算符 对两个表达式进行逻辑“与”运算。 result = expression1 And expression2 参数 result 任意数值变量。 expression1
运算符(+) 计算两个数之和。 result = expression1 + expression2 参数 result 任意数值变量。 expression1 任意表达式。 exp
我对此感到困惑snippet : var n1 = 5-"4"; var n2 = 5+"4"; alert(n1); alert(n2); 我知道 n1 是 1。那是因为减号运算符会将字符串“4”转
我想我会得到 12,而不是 7。 w++,那么w就是4,也就是100,而w++, w 将是 8,1000;所以 w++|z++ 将是 100|1000 = 1100 将是 12。 我怎么了? int
Xor 运算符 对两个表达式进行逻辑“异或”运算。 result = expression1 Xor expression2 参数 result 任意数值变量。 expression1
Mod 运算符 两个数值相除并返回其余数。 result = number1 Mod number2 参数 result 任意数值变量。 number1 任意数值表达式。 numbe
Imp 运算符 对两个表达式进行逻辑蕴涵运算。 result = expression1 Imp expression2 参数 result 任意数值变量。 expression1 任
Eqv 运算符 执行两个表达式的逻辑等价运算。 result = expression1 Eqv expression2 参数 result 任意数值变量。 expression1 任
我有一个运算符重载的简单数学 vector 类。我想为我的运算符(operator)获取一些计时结果。我可以通过计时以下代码轻松计时我的 +=、-=、*= 和/=: Vector sum; for(s
我是用户定义比较运算符的新手。我正在读一本书,其中提到了以下示例: struct P { int x, y; bool operator、运算符<等),我们
在 SQL 的维基百科页面上,有一些关于 SQL 中 bool 逻辑的真值表。 [1] 维基百科页面似乎来源于 SQL:2003 标准。 等号运算符 (=) 的真值表与 SQL:2003 草案中的 I
我遇到了一个奇怪的 C++ 运算符。 http://www.terralib.org/html/v410/classoracle_1_1occi_1_1_number.html#a0f2780081f
我正在阅读关于 SO 和 answers 中的一个问题,它被提到为: If no unambiguous matching deallocation function can be found, pr
我偶然发现了这个解决方案,但我无法理解其中到底发生了什么。谁能解释一下! 据我了解,它试图通过计算一半的单元格然后将其加倍来计算 a*b 网格中的单元格数量。但是我无法理解递归调用。 请不要建议其他解
Go的基本类型 布尔类型bool 长度:1字节 取值:布尔类型的取值只能是true或者false,不能用数字来表示 整型 通用整型 int / uint(有符号 / 无符号,下面也类似) 长度:根据运
在本教程中,您将学习JavaScript中可用的不同运算符,以及在示例的帮助下如何使用它们。 什么是运算符? 在JavaScript中,运算符是一种特殊符号,用于对运算数(值和变量)执行操作。例如,
我是一名优秀的程序员,十分优秀!