最近在学习 matlab 面向对象编程。发现可以在定义类的时候对属性作出各种限制。例如可以设定 Access 属性
public (默认值)- 可以从任何代码访问该属性。
protected - 可以从定义类或其子类访问该属性。
private - 该属性只能由定义类的成员访问。
对此属性进行访问和设置的类的列表。将类指定为单个 meta.class 对象或 meta.class 对象的元胞数组。有关详细信息,请参阅 属性访问列表。
我想请教一下,在现实工作中基于什么原因要对属性的可见性,可访问性,可赋值性,可引用性等等作出各种限制?可否提供几个场景案例加以说明?
如果是 chat gpt 的答案请注明
1
nash1000 2023-07-26 15:52:11 +08:00
可以隐藏内部的属性和方法的实现,便于后期维护和扩展,并提高安全性,这种问题太适合 chatgpt 回答了,你自己问下 chatgpt 肯定回答的更全;
|
2
Ayanokouji 2023-07-26 17:12:01 +08:00
大部分场景确实没什么用,比如 kotlin 的设计,就直接可以赋值。
|
3
gadfly3173 2023-08-11 18:15:18 +08:00 via Android
比如说有个要存数据库的对象,里面一个 string 字段存 javaClass ,一个 string 存序列化之后的值(比如不是 json ,json 序列化无法解决等等)。你希望 javaClass (它也可以是其他标识符)不会被乱写,那么你可以将这两个字段定义为 javaClass 和 valueString ,对外只提供 getValue 和 setValue 。getValue 直接获取的就是反序列化的对象了。
|
4
ShineSmile 345 天前 1
道理我都懂,为什么标签里有个 ass 。
我说一个情景,比如你写了一个类给我用,我在初始化这个类对象之后不应该“自由的”修改类的字段/属性,因为会影响你这个类的工作(方法),这个时候你把字段和属性掩蔽起来,就不用担心我瞎改了。 |