Skip to content

Order metadata to enforce appearance at the end of a sorted collection #34670

Open
@mipo256

Description

@mipo256

Overview

I kindly want to ask to resume the conversation on this topic.

It seems, that people have to deal with this problem.

What is desired, is that assume we have 3 beans: A, B and NoOp. And I assemble them into a List somewhere via:

@Autowired
private List<CommonInterface> list;

And what I want is the following:

for (var impl : list) {
    if (impl.supports(o)) {
        impl.doWork(o);
    }
}

The NoOp implementation is required to be the last, since it is fallback. But I really do not care about the order of other beans in the List. What I want is to ensure, that the NoOp bean is the last one in the List.

The problem is that simply adding @Order with the lowest priority to the NoOp will not work.

I can, of course, define the @Order with higher priority for each bean except for NoOp, but this requires that every time a new implementation of CommonInterface being added, the developer must not forget about adding the corresponding order marker as well. Otherwise, the NoOp may not be the last, which can lead and probably would lead to bugs.

The deeper problem is that if I deal with already compiled code, and I cannot physically add any @Order/Ordered to the compiled implementations, but I need to add my own to the end of the list.

I hope we can collaboratively find a solution. Thank you.

Related Issues

Metadata

Metadata

Assignees

No one assigned

    Labels

    in: coreIssues in core modules (aop, beans, core, context, expression)type: enhancementA general enhancement

    Type

    No type

    Projects

    No projects

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions