我试图理解为什么我会得到这些结果(这不是我预期的原因)”
public interface ICommandAble
{ }
public interface ILogAble extends ICommandAble
{ }
public interface IMonitorAble extends ICommandAble
{ }
public abstract class ClassAbs
{ }
public class A extends ClassAbs implements IMonitorAble, ILogAble
{ }
测试方法:
public void test()
{
A a=new A();
List<ICommandAble>commandList=new ArrayList<ICommandAble>()
if (a instanceof ILogAble)
{
ILogAble logAbleItem=(ILogAble)a;
commandList.add(logAbleItem);
}
if (a instanceof IMonitorAble) {
IMonitorAble monitorAbleItem=(IMonitorAble)a;
commandList.add(monitorAbleItem);
}
for(ICommandAble item: commandList)
{
if(item instanceof IMonitorAble)
{
log.debug("is monitorable");
}
if(item instanceof ILogAble)
{
log.debug("is logable");
}
}
输出是:
2013-04-22 18:25:00,498 com ... [DEBUG] 是可监控的
2013-04-22 18:25:02,150 com.... [DEBUG] 是可登录的
2013-04-22 18:25:08,322 com.... [DEBUG] 是可监控的
2013-04-22 18:25:08,977 com.... [DEBUG] 是可登录的
我希望看到:。
2013-04-22 18:25:00,498 com ... [DEBUG] 是可监控的
2013-04-22 18:25:02,150 com.... [DEBUG] 是可登录的
我在这里想念什么?
我现在明白我在这里想念什么了。但是我应该如何重新设计它以使其在第二个实例中仅输入一次?我的意图是看到这个:
2013-04-22 18:25:00,498 com... [DEBUG] is monitorable
2013-04-22 18:25:02,150 com.... [DEBUG] is logable
有什么重新设计的建议吗?
否则,我将对所有内容进行双重执行,而我的意图是每个内容只执行一次。
谢谢,雷。