为什么JavaMail Transport.send()是一个静态方法?

时间:2010-02-16 16:36:37

标签: java javamail api-design

我正在修改我没有编写的使用JavaMail的代码,并且在理解为什么JavaMail API的设计方式有点麻烦。我觉得,如果我理解,我可以做得更好。

我们打电话:

transport = session.getTransport("smtp");
transport.connect(hostName, port, user, password);

那么为什么Eclipse会警告我:

transport.send(message, message.getAllRecipients());

是对静态方法的调用吗?

如果我无法使用该对象发送消息,为什么我会获取Transport对象并提供特定于它的设置? Transport类如何知道用于发送消息的服务器和其他设置?它工作正常,很难相信。如果我为两个不同的服务器实例化了Transport对象,该怎么办?怎么会知道使用哪一个?

在写这个问题的过程中,我发现我应该真的在呼唤:

transport.sendMessage(message, message.getAllRecipients());

那么静态Transport.send()方法的目的是什么?这只是糟糕的设计,还是有这样的原因?

2 个答案:

答案 0 :(得分:8)

Transport.send()基本上是一种方便的方法。是的,如果您要管理自己的Transport个实例,请致电sendMessage()

我不确定我认为它设计不好,因为经常你不关心管理传输和监控传输的细节。破解send()方法,看看它为你做了什么。其他命名或放置此方法的方法可能稍微好一点。

答案 1 :(得分:5)

javadoc说:

Send是一种静态方法,可以创建和管理自己的连接。与用于调用此方法的任何Transport实例关联的任何连接都将被忽略并且不会使用。只应使用表单Transport.send(msg);调用此方法,并且永远不应使用实例变量调用此方法。

是的,可能,设计不好