I don’t believe I am implementing the factory pattern correctly because the Application class’ createDocument method accepts any class type, not just subclasses of Document.
In other words, is there a way I can restrict the createDocument method to only accept subclasses of Document?
-
Document.java
package com.example.factory; public abstract class Document { public Document() { System.out.println("New Document instance created: " + this.toString()); } } -
DrawingDocument.java
package com.example.factory public class DrawingDocument extends Document { public DrawingDocument() { System.out.println("New DrawingDocument instance created: " this.toString()); } } -
Application.java
package com.example.factory; public class Application { public <T> T createDocument(Class<T> documentClass) { try { return documentClass.newInstance(); } catch (InstantiationException e) { throw new IllegalArgumentException(e); } catch (IllegalAccessException e) { throw new IllegalArgumentException(e); } }; } -
Main.java
package com.example.factory; public static void main(String[] args) { Application application = new Application(); application.createDocument(DrawingDocument.class); }
You should bound your generic so that it is only using T’s that inherit Document.
example: