What does “Static factories returned object need not exist” mean?









up vote
4
down vote

favorite












While reading "Effective Java" J.Bloch came across this statement




A fifth advantage of static factories is that the class of the returned object need not exist when the class containing the method is written.




What does it mean? Can someone explain it with some examples ?










share|improve this question









New contributor




gg ff is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.























    up vote
    4
    down vote

    favorite












    While reading "Effective Java" J.Bloch came across this statement




    A fifth advantage of static factories is that the class of the returned object need not exist when the class containing the method is written.




    What does it mean? Can someone explain it with some examples ?










    share|improve this question









    New contributor




    gg ff is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
    Check out our Code of Conduct.





















      up vote
      4
      down vote

      favorite









      up vote
      4
      down vote

      favorite











      While reading "Effective Java" J.Bloch came across this statement




      A fifth advantage of static factories is that the class of the returned object need not exist when the class containing the method is written.




      What does it mean? Can someone explain it with some examples ?










      share|improve this question









      New contributor




      gg ff is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.











      While reading "Effective Java" J.Bloch came across this statement




      A fifth advantage of static factories is that the class of the returned object need not exist when the class containing the method is written.




      What does it mean? Can someone explain it with some examples ?







      java






      share|improve this question









      New contributor




      gg ff is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.











      share|improve this question









      New contributor




      gg ff is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.









      share|improve this question




      share|improve this question








      edited Nov 10 at 15:53









      Koray Tugay

      8,38026109214




      8,38026109214






      New contributor




      gg ff is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.









      asked Nov 10 at 15:50









      gg ff

      234




      234




      New contributor




      gg ff is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.





      New contributor





      gg ff is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.






      gg ff is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.






















          1 Answer
          1






          active

          oldest

          votes

















          up vote
          2
          down vote



          accepted










          It means that the API of your static factory method can return an interface type, of which the implementation won't be written or generated until later.



          As an example:



          public static MyInterface getMyInterfaceInstance() 
          //load instance dynamically and return it.



          In this case, the factory method only needs the MyInterface interface to exist when it's being compiled. The actual implementation can be loaded dynamically at runtime in many ways, including:



          • Creating a proxy object

          • Reflection (configurable implementation class name loaded at runtime)

          • Looking up a service loader

          In particular, the last two options simply mean that the implementation class can be written in a different module (and many modules can provide an implementation of the interface), and these implementation classes will be discovered at runtime - which makes it possible for the static factory method to be written before the actual implementation class.






          share|improve this answer




















            Your Answer






            StackExchange.ifUsing("editor", function ()
            StackExchange.using("externalEditor", function ()
            StackExchange.using("snippets", function ()
            StackExchange.snippets.init();
            );
            );
            , "code-snippets");

            StackExchange.ready(function()
            var channelOptions =
            tags: "".split(" "),
            id: "1"
            ;
            initTagRenderer("".split(" "), "".split(" "), channelOptions);

            StackExchange.using("externalEditor", function()
            // Have to fire editor after snippets, if snippets enabled
            if (StackExchange.settings.snippets.snippetsEnabled)
            StackExchange.using("snippets", function()
            createEditor();
            );

            else
            createEditor();

            );

            function createEditor()
            StackExchange.prepareEditor(
            heartbeatType: 'answer',
            convertImagesToLinks: true,
            noModals: true,
            showLowRepImageUploadWarning: true,
            reputationToPostImages: 10,
            bindNavPrevention: true,
            postfix: "",
            imageUploader:
            brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
            contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
            allowUrls: true
            ,
            onDemand: true,
            discardSelector: ".discard-answer"
            ,immediatelyShowMarkdownHelp:true
            );



            );






            gg ff is a new contributor. Be nice, and check out our Code of Conduct.









             

            draft saved


            draft discarded


















            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53240626%2fwhat-does-static-factories-returned-object-need-not-exist-mean%23new-answer', 'question_page');

            );

            Post as a guest















            Required, but never shown

























            1 Answer
            1






            active

            oldest

            votes








            1 Answer
            1






            active

            oldest

            votes









            active

            oldest

            votes






            active

            oldest

            votes








            up vote
            2
            down vote



            accepted










            It means that the API of your static factory method can return an interface type, of which the implementation won't be written or generated until later.



            As an example:



            public static MyInterface getMyInterfaceInstance() 
            //load instance dynamically and return it.



            In this case, the factory method only needs the MyInterface interface to exist when it's being compiled. The actual implementation can be loaded dynamically at runtime in many ways, including:



            • Creating a proxy object

            • Reflection (configurable implementation class name loaded at runtime)

            • Looking up a service loader

            In particular, the last two options simply mean that the implementation class can be written in a different module (and many modules can provide an implementation of the interface), and these implementation classes will be discovered at runtime - which makes it possible for the static factory method to be written before the actual implementation class.






            share|improve this answer
























              up vote
              2
              down vote



              accepted










              It means that the API of your static factory method can return an interface type, of which the implementation won't be written or generated until later.



              As an example:



              public static MyInterface getMyInterfaceInstance() 
              //load instance dynamically and return it.



              In this case, the factory method only needs the MyInterface interface to exist when it's being compiled. The actual implementation can be loaded dynamically at runtime in many ways, including:



              • Creating a proxy object

              • Reflection (configurable implementation class name loaded at runtime)

              • Looking up a service loader

              In particular, the last two options simply mean that the implementation class can be written in a different module (and many modules can provide an implementation of the interface), and these implementation classes will be discovered at runtime - which makes it possible for the static factory method to be written before the actual implementation class.






              share|improve this answer






















                up vote
                2
                down vote



                accepted







                up vote
                2
                down vote



                accepted






                It means that the API of your static factory method can return an interface type, of which the implementation won't be written or generated until later.



                As an example:



                public static MyInterface getMyInterfaceInstance() 
                //load instance dynamically and return it.



                In this case, the factory method only needs the MyInterface interface to exist when it's being compiled. The actual implementation can be loaded dynamically at runtime in many ways, including:



                • Creating a proxy object

                • Reflection (configurable implementation class name loaded at runtime)

                • Looking up a service loader

                In particular, the last two options simply mean that the implementation class can be written in a different module (and many modules can provide an implementation of the interface), and these implementation classes will be discovered at runtime - which makes it possible for the static factory method to be written before the actual implementation class.






                share|improve this answer












                It means that the API of your static factory method can return an interface type, of which the implementation won't be written or generated until later.



                As an example:



                public static MyInterface getMyInterfaceInstance() 
                //load instance dynamically and return it.



                In this case, the factory method only needs the MyInterface interface to exist when it's being compiled. The actual implementation can be loaded dynamically at runtime in many ways, including:



                • Creating a proxy object

                • Reflection (configurable implementation class name loaded at runtime)

                • Looking up a service loader

                In particular, the last two options simply mean that the implementation class can be written in a different module (and many modules can provide an implementation of the interface), and these implementation classes will be discovered at runtime - which makes it possible for the static factory method to be written before the actual implementation class.







                share|improve this answer












                share|improve this answer



                share|improve this answer










                answered Nov 10 at 16:10









                ernest_k

                17.6k41836




                17.6k41836




















                    gg ff is a new contributor. Be nice, and check out our Code of Conduct.









                     

                    draft saved


                    draft discarded


















                    gg ff is a new contributor. Be nice, and check out our Code of Conduct.












                    gg ff is a new contributor. Be nice, and check out our Code of Conduct.











                    gg ff is a new contributor. Be nice, and check out our Code of Conduct.













                     


                    draft saved


                    draft discarded














                    StackExchange.ready(
                    function ()
                    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53240626%2fwhat-does-static-factories-returned-object-need-not-exist-mean%23new-answer', 'question_page');

                    );

                    Post as a guest















                    Required, but never shown





















































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown

































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown







                    Popular posts from this blog

                    Top Tejano songwriter Luis Silva dead of heart attack at 64

                    ReactJS Fetched API data displays live - need Data displayed static

                    政党