以下是我的界面-
public interface IDBClient {
public String read(ClientInput input);
}
这是我对接口的实现-
public class DatabaseClient implements IDBClient {
@Override
public String read(ClientInput input) {
}
}
现在我有一个工厂,它得到这样的实例DatabaseClient
-
IDBClient client = DatabaseClientFactory.getInstance();
....
现在,我需要调用接受参数read
的my方法,下面是相同的类。本课不是我写的,所以这是我对此有疑问的原因,我非常确定这是错误的做法。DatabaseClient``ClientInput
public final class ClientInput {
private Long userid;
private Long clientid;
private Long timeout_ms = 20L;
private boolean debug;
private Map<String, String> parameterMap;
public ClientInput(Long userid, Long clientid, Map<String, String> parameterMap, Long timeout_ms, boolean debug) {
this.userid = userid;
this.clientid = clientid;
this.parameterMap = parameterMap;
this.timeout_ms = timeout_ms;
this.debug = debug;
}
}
因此,当客户调用的read
方法时DatabaseClient
,他们将ClientInput
像这样创建参数,然后使用工厂获取的实例,DatabaseClient
然后相应地调用read方法。
Map<String, String> paramMap = new HashMap<String, String>();
paramMap.put("attribute", "segmentation");
ClientInput input = new ClientInput(109739281L, 20L, paramMap, 1000L, true);
IDBClient client = DatabaseClientFactory.getInstance();
client.read(input);
问题陈述:-
userid
,clientid
,timeout_ms
应该是Long
对象或者只是long
在ClientInput
上课吗?negative user ids
,negative client id
,negative timeout
价值等等等等。那么,我应该这样做验证?我应该在ClientInput
类的构造函数中还是在其他地方进行此验证检查?这样做的更好方法是什么,我应该如何进行验证?我认为没有一个正确的答案。一些建议:
我看到之间最大的区别long
,并Long
在这方面是Long
可能null
。如果有可能您缺少值,则该Long
对象将很有帮助,因为它null
可以指示值丢失。如果您使用的是原语,则必须使用一些特殊的值来表示缺失,这很可能会一团糟。除非您计划制作一百万个这样的数组然后进行序列化,否则速度或大小不太可能成为问题。
我对验证逻辑的偏爱是ValidationException
在事情可能失败的时候抛出某种习惯。如果您只是使用构造函数创建这些东西,那么最简单的方法就是在那里进行验证,例如
public ClientInput(Long userid, Long clientid, Map<String, String> parameterMap, Long timeout_ms, boolean debug) throws ValidationException {
if (userid == null) throw new ValidationException("UserId is required");
...etc, etc...
}
最终,ValidationException
仅当您可以在可以使用它做一些有用的事情时将其捕获时才有用-将其回显给用户或其他任何用户。
问题内容: 我怕可变参数。我不知道该怎么用。 另外,让人们随心所欲地传递争论是很危险的。 什么样的上下文示例将是使用它们的好地方? 问题答案: 对于需要处理不确定数目的对象的任何方法,Varargs都是有用的。一个很好的例子是。格式字符串可以接受任意数量的参数,因此你需要一种机制来传递任意数量的对象。
(1)重载是多态的集中体现,在类中,要以统一的方式处理不同类型数据的时候,可以用重载。 (2)重写的使用是建立在继承关系上的,子类在继承父类的基础上,增加新的功能,可以用重写。 (3)简单总结: 重载是多样性,重写是增强剂; 目的是提高程序的多样性和健壮性,以适配不同场景使用时,使用重载进行扩展; 目的是在不修改原方法及源代码的基础上对方法进行扩展或增强时,使用重写; 生活例子: 你想吃一碗面,我
问题内容: 奇怪的是: 似乎或多或少被定义为。通过这种方式很容易产生错误: 一些fname意外地以else块结尾。修复很简单,我们应该改用它,但是从表面上看,这似乎是一种不错的pythonic方式,并且比“正确”的方式更具可读性。 由于字符串是不可变的,所以为什么字符串错误是什么技术细节?什么时候进行身份检查更好,什么时候进行平等检查更好? 问题答案: 据我所知,检查对象身份是否相等。由于没有强制
问题内容: 我喜欢使用任何语言的访问控制,但是我发现在Java中,我几乎从不(如果有的话)使用package- private 访问修饰符(或缺少它)。 我知道内部类可以是,,或,但外类只能是或。为什么外层阶级会成为事实?限制整个包而不是子类看到的类/方法/字段有什么好处? 问题答案: 当我想向包外的用户(和其他类)隐藏实现细节时,我使用类和方法。 例如,如果我有一个接口和一个创建该接口实例的工厂
问题内容: 我目前正在Java课程中学习有关类继承的信息,我不知道何时使用该调用? 编辑: 我发现使用此代码示例: 因此,我知道在这里,你必须使用它来访问超类中的变量。但是,在其他情况下,该怎么;办?在其自己的? 问题答案: 精确 调用始终是多余的。它明确地在做否则会隐式地做的事情。这是因为如果你省略对超级构造函数的调用,则无论如何都将自动调用无参数的超级构造函数。并不是说这是不好的风格。有些人喜
问题内容: 我如何使用AtomicBoolean?该类的作用是什么? 问题答案: 当有多个线程需要检查并更改布尔值时。例如: 这不是线程安全的。您可以使用以下方法修复它: