简体   繁体   English

Java Object 具有不同类型的子类,包括枚举

[英]Java Object with subclasses of different type including enum

I like to think top/down rather than bottom/up, so here is directly my final goal:我喜欢考虑自上而下而不是自下而上,所以这直接是我的最终目标:

My goal: A "aQuery" built with different "PlQryElement"s (Pl stands for 'Playlist' since the context here is a 'smart playlist' for music playlist manager):我的目标:使用不同的“PlQryElement”构建的“aQuery”(Pl 代表“播放列表”,因为这里的上下文是音乐播放列表管理器的“智能播放列表”):

List<PlQry_Element> aQuery = new ArrayList<PlQry_Element>();

I should obviously instantiate the 'PlQry_Elements', and then use the aQuery.add(...);我显然应该实例化“PlQry_Elements”,然后使用aQuery.add(...); . . Resulting of building up my final query.建立我的最终查询的结果。

Here is the "PlQry_Element" possible:这是可能的“PlQry_Element”:

  • A "PlQryEl_Parentese" (open or close, parenthese) --> I used 'enum' for this一个“PlQryEl_Parentese”(打开或关闭,括号)->我为此使用了“枚举”
  • A "PlQryEl_Condition" (a condition having it's own building up) --> I used a specific object for this一个“PlQryEl_Condition”(一个自己建立的条件)——>我为此使用了一个特定的 object
  • A "PlQryEl_BoolOperator" (essentially 'AND' / 'OR') --> I used 'enum' for this一个“PlQryEl_BoolOperator”(本质上是“与”/“或”)——>我为此使用了“枚举”

What I would think:我会怎么想:

  • Using an abstract class: All "PlQryEl_..." should be subclasses from an abstract class "PlQryElement".使用抽象 class:所有“PlQryEl_...”都应该是抽象 class“PlQryElement”的子类。 But this obviously does not work with 'enum' which are not "implementable".但这显然不适用于“可实施”的“枚举”。
  • Another thought was to use Polymorphism... Could not get it to work.另一个想法是使用多态性......无法让它工作。

Question: How can I achieve my very first goal... Without changing my 'enum' objects into 'classes'?问题:我怎样才能实现我的第一个目标......而不将我的“枚举”对象更改为“类”?

Any help would be greatly appreciated;.. Thank you in advance.-)...任何帮助将不胜感激;..提前谢谢你.-)...


Here are the classes WITHOUT 'implements':以下是没有“实现”的类:

PlQryEl_Parenthese --> PlQryEl_Parenthese -->

package application.query.element;

public enum PlQryEl_Parenthese {
    PARENTHESES_OPEN("("),
    PARENTHESES_CLOSE(")");

    String symbol;
    
    PlQryEl_Parenthese(String symbol) {
        this.symbol = symbol;
    }
};

PlQryEl_Condition --> PlQryEl_Condition -->

package application.query.element;

import application.query.element.cond.PlQryEl_Cond_Object;
import application.query.element.cond.PlQryEl_Cond_Operator;

public class PlQryEl_Condition {
    PlQryEl_Cond_Object aObject = PlQryEl_Cond_Object.PLAYLIST;
    String sField="";
    PlQryEl_Cond_Operator aOparator = PlQryEl_Cond_Operator.EQUAL;
    String sValue = "";
    
    public PlQryEl_Condition(PlQryEl_Cond_Object aObject, String sField, PlQryEl_Cond_Operator aOparator, String sValue) {
        super();
        this.aObject = aObject;
        this.sField = sField;
        this.aOparator = aOparator;
        this.sValue = sValue;
    }
};

PlQryEl_BoolOperator --> PlQryEl_BoolOperator -->

    package application.query.element;
    
    public enum PlQryEl_BoolOperator {
        LINK_OR("or"),
        LINK_AND("and");
    
        String symbol;
        
        PlQryEl_BoolOperator(String symbol) {
            this.symbol = symbol;
        }
    };

And for interest here are the objects about the 'PlQryEl_Condition' class:这里感兴趣的是关于“PlQryEl_Condition”class 的对象:

PlQryEl_Cond_Object --> PlQryEl_Cond_Object -->

package application.query.element.cond;

public enum PlQryEl_Cond_Object {
    PLAYLIST("Playlist","vPlaylist"),
    TRACK("Track","vTrack");

    String symbol;
    String dbViewName;
    
    PlQryEl_Cond_Object(String symbol, String dbViewName) {
        this.symbol = symbol;
        this.dbViewName = dbViewName;
    }
};

PlQryEl_Cond_Operator --> PlQryEl_Cond_Operator -->

package application.query.element.cond;

public enum PlQryEl_Cond_Operator {
    EQUAL("="),
    GREATER(">"),
    SMALLER("<"),
    EMPTY("is empty (null, NA, ...)"),
    INLIST("in list");

    String symbol;
    String dbViewName;
    
    PlQryEl_Cond_Operator(String symbol) {
        this.symbol = symbol;
    }
};

As more often than never the answer is inside the question... This was the case here !答案往往就在问题之内……这里就是这种情况!

The solution I put in place was to wrap a 'class' around the enums in order to make them 'implementable'.我采用的解决方案是在枚举周围包裹一个“类”,以使它们“可实施”。

This solved, obviously the case... But is it the only/best solution?这解决了,显然是这样......但它是唯一/最好的解决方案吗?

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM