我正在使用 InetValidator
在我的项目中从apache.commons初始化以验证ip地址。在浏览源代码时,
public class InetAddressValidator implements Serializable {
private static final int IPV4_MAX_OCTET_VALUE = 255;
private static final int MAX_UNSIGNED_SHORT = 65535;
private static final int BASE_16 = 16;
private static final long serialVersionUID = -919201640201914789L;
private static final String IPV4_REGEX = "^(\\d{1,3})\\.(\\d{1,3})\\.(\\d{1,3})\\.(\\d{1,3})$";
private static final int IPV6_MAX_HEX_GROUPS = 8;
private static final int IPV6_MAX_HEX_DIGITS_PER_GROUP = 4;
private static final InetAddressValidator VALIDATOR = new InetAddressValidator();
private final RegexValidator ipv4Validator = new RegexValidator("^(\\d{1,3})\\.(\\d{1,3})\\.(\\d{1,3})\\.(\\d{1,3})$");
public InetAddressValidator() {
}
public static InetAddressValidator getInstance() {
return VALIDATOR;
}
我注意到有一个 VALIDATOR
再次调用构造函数的字段。我搞不懂的是,如果我创建一个这个类的新示例,
InetAddressValidator addressValidator = new InetAddressValidator();
它是否会递归地创建同一类的新示例(作为字段) VALIDATOR
每次创建一个新示例)最终我会耗尽堆空间吗?
我还没有测试过这个,但想知道这是不是我在测试时必须记住的东西。
2条答案
按热度按时间kfgdxczn1#
递归调用
inetaddressvalidator addressvalidator=新的inetaddressvalidator();递归调用
xbp102n02#
它是一个静态字段,因此在类加载时只示例化一次,而不是在构造函数中每个示例示例化一次。