我在谷歌中搜索了case类和class之间的区别。每个人都提到,当你想在类上做模式匹配时,用例类。否则使用类,并提到一些额外的好处,如等号和哈希代码重写。但是这些就是为什么应该使用case类而不是类的唯一原因吗?
我想在Scala中应该有一些非常重要的原因。有什么解释,或者有资源可以学习更多关于Scala案例类的知识吗?
我在谷歌中搜索了case类和class之间的区别。每个人都提到,当你想在类上做模式匹配时,用例类。否则使用类,并提到一些额外的好处,如等号和哈希代码重写。但是这些就是为什么应该使用case类而不是类的唯一原因吗?
我想在Scala中应该有一些非常重要的原因。有什么解释,或者有资源可以学习更多关于Scala案例类的知识吗?
当前回答
Case类可以进行模式匹配 Case类自动定义hashcode和equals Case类自动为构造函数参数定义getter方法。
(除了最后一个,你已经提到了所有的)。
这些是与常规课程的唯一区别。
其他回答
下面列出了case类的一些关键特性
Case类是不可变的。 可以实例化case类而不需要new关键字。 案例类可以根据值进行比较
scala fiddle的示例代码,摘自scala文档。
https://scalafiddle.io/sf/34XEQyE/0
Case类可以被看作是普通的、不可变的数据保存对象,应该完全依赖于它们的构造函数参数。
这个函数概念允许我们
使用紧凑的初始化语法(Node(1, Leaf(2), None))) 使用模式匹配分解它们 是否隐含地定义了相等比较
结合继承,case类被用来模拟代数数据类型。
如果一个对象在内部执行有状态计算或显示其他类型的复杂行为,那么它应该是一个普通类。
根据Scala的文档:
Case类只是常规类,它们是: 默认是不可变的 可通过模式匹配进行分解 用结构相等代替参照进行比较 简单的实例化和操作
case关键字的另一个特性是编译器自动为我们生成几个方法,包括Java中熟悉的toString、equals和hashCode方法。
Case类可以进行模式匹配 Case类自动定义hashcode和equals Case类自动为构造函数参数定义getter方法。
(除了最后一个,你已经提到了所有的)。
这些是与常规课程的唯一区别。
在之前的回答中没有提到的一个重要问题是身份。常规类的对象具有同一性,因此即使两个对象的所有字段值相同,它们仍然是不同的对象。然而,对于case类实例,相等性纯粹是根据对象字段的值定义的。