为什么要对“类中属性”的可访问性作出各种限制?

2023-07-26 14:52:04 +08:00
 huzhikuizainali

最近在学习 matlab 面向对象编程。发现可以在定义类的时候对属性作出各种限制。例如可以设定 Access 属性

public (默认值)- 可以从任何代码访问该属性。

protected - 可以从定义类或其子类访问该属性。

private - 该属性只能由定义类的成员访问。

对此属性进行访问和设置的类的列表。将类指定为单个 meta.class 对象或 meta.class 对象的元胞数组。有关详细信息,请参阅 属性访问列表。

我想请教一下,在现实工作中基于什么原因要对属性的可见性,可访问性,可赋值性,可引用性等等作出各种限制?可否提供几个场景案例加以说明?

如果是 chat gpt 的答案请注明

847 次点击
所在节点    Java
4 条回复
nash1000
2023-07-26 15:52:11 +08:00
可以隐藏内部的属性和方法的实现,便于后期维护和扩展,并提高安全性,这种问题太适合 chatgpt 回答了,你自己问下 chatgpt 肯定回答的更全;
Ayanokouji
2023-07-26 17:12:01 +08:00
大部分场景确实没什么用,比如 kotlin 的设计,就直接可以赋值。
gadfly3173
2023-08-11 18:15:18 +08:00
比如说有个要存数据库的对象,里面一个 string 字段存 javaClass ,一个 string 存序列化之后的值(比如不是 json ,json 序列化无法解决等等)。你希望 javaClass (它也可以是其他标识符)不会被乱写,那么你可以将这两个字段定义为 javaClass 和 valueString ,对外只提供 getValue 和 setValue 。getValue 直接获取的就是反序列化的对象了。
ShineSmile
2023-12-18 21:54:27 +08:00
道理我都懂,为什么标签里有个 ass 。
我说一个情景,比如你写了一个类给我用,我在初始化这个类对象之后不应该“自由的”修改类的字段/属性,因为会影响你这个类的工作(方法),这个时候你把字段和属性掩蔽起来,就不用担心我瞎改了。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/959897

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX