码迷,mamicode.com
首页 > 数据库 > 详细

Effective Java 英文 第二版 读书笔记 Item 13:Minimize the accessibility of classes and members

时间:2016-07-12 15:18:16      阅读:168      评论:0      收藏:0      [点我收藏+]

标签:

访问修饰符的可见域

• private—The member is accessible only from the top-level class where it is declared.
• package-private—The member is accessible from any class in the package
where it is declared. Technically known as default access, this is the access level
you get if no access modifier is specified.
• protected—The member is accessible from subclasses of the class where it is
declared (subject to a few restrictions [JLS, 6.6.2]) and from any class in the
package where it is declared.
• public—The member is accessible from anywhere.

 

Instance fields should never be public ,so classes with public mutable fields are not thread-safe

it is wrong for a class
to have a public static final array field, or an accessor that returns such a
field. If a class has such a field or accessor, clients will be able to modify the contents
of the array. This is a frequent source of security holes:
// Potential security hole!
public static final Thing[] VALUES = { ... };

 

Beware of the fact that many IDEs generate accessors that return references to private
array fields, resulting in exactly this problem. There are two ways to fix the
problem. You can make the public array private and add a public immutable list:

private static final Thing[] PRIVATE_VALUES = { ... };
public static final Thing[] values() {
return PRIVATE_VALUES.clone();
}

Effective Java 英文 第二版 读书笔记 Item 13:Minimize the accessibility of classes and members

标签:

原文地址:http://www.cnblogs.com/linkarl/p/5643697.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!