javaserializationcdiconversation-scope

Is it safe to mark the CDI conversation interface as transient?


Is the conversation interface you can inject in a @ConversationScoped bean safe to mark transient (ie. will CDI deal with it is during serialization) or I do I need a custom read/writeObject?

@ConversationScoped
    public class CDIConversationScopedBean implements Serializable {
        private static final long serialVersionUID = 1L;
        @Inject
        private transient Conversation conversation; // <<-- transient ok?

FindBugs is complaining about a non-transient non-serializable instance field.


Solution

  • TL;DR: Yes, it is safe. Explanation:

    Since the Conversation class doesn't implement the Serializable interface as well the static analyzers usually complain that all the fields must be either Serializable or transient even if the class is never explicitly serialized or deserialized.

    Firstly, your snippet is a bit questionable, why do you implement this marker interface - so do you plan to serialize this class? You might want to add the generated or default Serial Version UID.

    To solve this, make the field transient if you don't plan to make de/serialize the class - it's harmless and will not affect the behavior of Conversation. See Java 8 specification, chapter 8.3.1.3.

    Variables may be marked transient to indicate that they are not part of the persistent state of an object.

    If you plan, make Conversation implement Serializable and treat its fields in the same way.