当前位置: 首页 > 面试题库 >

接口上用于强制一致性的静态方法的替代方法

牧献
2023-03-14
问题内容

在Java中,我希望能够定义标记器接口,该标记器接口强制实现提供静态方法。例如,对于简单的文本序列化/反序列化,我希望能够定义一个看起来像这样的接口:

public interface TextTransformable<T>{

  public static T fromText(String text);

  public String toText();

由于Java中的接口不能包含静态方法(如其他许多文章/线程中所述:here和here,此代码不起作用。

但是,我正在寻找一种表达相同意图的合理范例,即对称方法,其中之一是静态的,由编译器强制执行。现在,我们能想到的最好的方法是某种静态工厂对象或通用工厂,这两种方法都不能令人满意。

注意:在我们的例子中,我们的主要用例是我们有许多很多的“值对象”类型-枚举或具有有限数量值的其他对象,通常不携带超出其值的状态,并且我们对其进行解析/解析-
每秒解析数千次,因此实际上要关心重用实例(例如Float,Integer等)及其对内存消耗/ gc的影响

有什么想法吗?

EDIT1: 为消除一些混乱-我们有许多不同的对象适合此模式-确实,我们试图为调用者提供2种语义的优雅的东西:

  • 作为合同的接口-统一的访问权限(例如TextTransformable作为一种功能)
  • 要求通过子类/实现来实现(例如,强迫他们实现自己的转换

就我们对Flyweight,FACTORY的想法而言,它们都是我们考虑过的选项,实际上,我们正在尝试查看是否可以找到比依赖JavaDoc所说的“实现工厂并委托调用它,或按照惯例将其暴露在XXX位置”


问题答案:

这确实适合Flyweight。基本上,这就是您要使用静态函数完成的工作。关于如何为Flyweight对象提供服务,以免创建数千个对象,这里有一些想法。

一个是工厂,尽管您没有说明原因(因此其他任何想法可能会遇到相同的问题),但您却说过您曾考虑过并拒绝了它,因此我将不再赘述。

另一个是让值类型具有一种可以为其转换器服务的方法。像这样:

 public class ValueType {
       public static final TextTransformable<ValueType> CONVERT = ....
 }

然后像这样使用它:

 ValueType value = ValueType.CONVERT.fromText(text);

 String text = ValueType.CONVERT.toText(value);

现在,这并不能强制所有ValueType都通过相同的机制提供其转换器,因为我认为您需要某种工厂。

编辑:我想我不知道您发现关于工厂的欠佳之处,但是我认为您专注于呼叫者,所以您的感觉如何:

  ValueType value = getTransformer(ValueType.class).fromText(text);

可以通过静态导入工厂和具有如下签名的方法来完成上述操作:

   public static <T> TextTransformable<T> getTransformer(Class<T> type) {
         ...
   }

找到合适的转换器的代码不一定是最漂亮的,但是从调用者的角度来看,一切都很好。

编辑2:进一步考虑这一点,我看到的是您想控制对象的构造。你真的不能那样做。换句话说,在Java中,您不能强制实施者使用或不使用工厂来创建其对象。他们总是可以公开一个公共构造函数。我认为您的问题是您对执行构造的机制不满意。如果这种理解是正确的,则可以使用以下模式。

您只能使用私有构造函数创建一个包装您的值类型的对象。该对象可能具有通用类型参数,以了解其包装的值类型。该对象使用静态工厂方法实例化,该方法采用工厂接口来创建“真实”值对象。所有使用该对象的框架代码都仅将此对象作为参数。它不直接接受值类型,并且没有该值类型的工厂就无法实例化该对象。

这种方法的问题在于它的局限性。创建对象(工厂接口支持的对象)只有一种方法,并且使用值对象的能力有限,因为处理这些文本元素的代码仅通过该对象具有有限的交互。

我猜他们说没有一个软件问题无法通过额外的间接层解决,但这可能是一座遥不可及的桥梁。至少是值得深思的。



 类似资料:
  • 问题内容: Java-8允许在接口内部定义静态方法,但仅通过接口名称限制其调用: 9.4:接口可以声明静态方法,这些方法在不引用特定对象的情况下被调用。 例如: 导致错误: 在JLS中,这种禁令经常有一种解释。在这种情况下,我没有发现任何详细信息。因此,我正在寻找对此规则的全面或权威的解释:为什么禁止通过特定的对象引用调用静态方法?它有什么坏处? 问题答案: 相当强烈的共识是,有关类的静态方法也不

  • 此具有方法 我迷路了...有人能解释一下吗

  • 现在的问题是,我是否可以创建这些函数一次,并像助手方法一样重用它们。 一个威胁是线程安全。我用一个简单的测试来检查这个JUnit测试: 我用的是VMLENS。我可以通过更改变量来优化测试,这样可以检查随机性。目的是查看这些使用相同函数的多个线程是否因为并发访问而混淆了它们的输入。测试没有返回任何阴性结果。请对测试是否符合目标做出评论。 上面使用的结果是否也可以应用于和? 对函数和字节码的更多熟悉可

  • 问题内容: 我们有一个给定的REST接口: 可以根据服务器配置,通过不同的逻辑“计算器”来实现此计算。 现在,我们正在设计每个计算器必须实现的Java接口。该接口将为每个REST服务提供一个方法。 鉴于所有REST(和HTTP)调用都是无状态的,因此每个方法都应该是静态的。但是,您不能在Java接口中定义静态方法。有没有针对这种情况的好的解决方法? 我们可以将这些方法定义为非静态方法,然后仅创建一

  • 为GUI创建了登录类,将所有GUI构造添加到一个方法中,以便我可以在启动时从我的主类中调用它。调用方法抛出错误“'GUILoginPage.this'不能从静态上下文中引用”。 这方面有什么解决办法?我理解不能使用的原因。但我没有看到任何解决方案

  • 问题内容: oracle一致性是否有任何开源替代方案? (顺便说一句,连贯性要花多少钱?) 问题答案: EhCache提供了不错的复制缓存,但与Coherence提供的功能集相去甚远。