Java Singleton getter/setter

 Clash Royale CLAN TAG#URR8PPP
Clash Royale CLAN TAG#URR8PPP
.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty margin-bottom:0;
up vote
0
down vote
favorite
I've created working setters/getters for an application, that will use a few different classes. This classes will use one class, that will store all data. I know, when I will use a standard constructor of container class, I'll get tons on nulls, due to different instance of container class.
I've created container class within a singleton, that works, but I wanted to ask if anything could be done better, or if this code follow the best practice.
public class Container 
 private String appName = null;
 private String appOwner = null;
 private Container() 
 System.out.println("Start");
 
 private static class SingletonHolder 
 private final static Container INSTANCE = new Container();
 
 public static Container getInstance() 
 return SingletonHolder.INSTANCE;
 
 public String getAppName() 
 return appName;
 
 public void setAppName(String appName) 
 this.appName = appName;
 
 public String getAppOwner() 
 return appOwner;
 
 public void setAppOwner(String appOwner) 
 this.appOwner = appOwner;
 
Sample class, that will use this container:
public class SecondClass 
 Container ctn = Container.getInstance();
Right now, when I use in main class:
ctn.setAppOwner(owner);
I get a proper value in any other classes, when I call this:
Container ctn = Container.getInstance();
ctn.getAppOwner();
Is that a good approach?
java singleton
add a comment |Â
up vote
0
down vote
favorite
I've created working setters/getters for an application, that will use a few different classes. This classes will use one class, that will store all data. I know, when I will use a standard constructor of container class, I'll get tons on nulls, due to different instance of container class.
I've created container class within a singleton, that works, but I wanted to ask if anything could be done better, or if this code follow the best practice.
public class Container 
 private String appName = null;
 private String appOwner = null;
 private Container() 
 System.out.println("Start");
 
 private static class SingletonHolder 
 private final static Container INSTANCE = new Container();
 
 public static Container getInstance() 
 return SingletonHolder.INSTANCE;
 
 public String getAppName() 
 return appName;
 
 public void setAppName(String appName) 
 this.appName = appName;
 
 public String getAppOwner() 
 return appOwner;
 
 public void setAppOwner(String appOwner) 
 this.appOwner = appOwner;
 
Sample class, that will use this container:
public class SecondClass 
 Container ctn = Container.getInstance();
Right now, when I use in main class:
ctn.setAppOwner(owner);
I get a proper value in any other classes, when I call this:
Container ctn = Container.getInstance();
ctn.getAppOwner();
Is that a good approach?
java singleton
 
 
 1
 
 
 
 
 "Is that a good approach? " No, see here: stackoverflow.com/questions/137975/⦠- and here: williamdurand.fr/2013/07/30/from-stupid-to-solid-code
 â Timothy Truckle
 Jan 7 at 19:39
 
 
 
 
 
 
 2
 
 
 
 
 These are all just getting and setting, right? Not much going on really. Not sure if it's even reviewable, as there is nothing.
 â Mast
 Jan 7 at 20:04
 
 
 
add a comment |Â
up vote
0
down vote
favorite
up vote
0
down vote
favorite
I've created working setters/getters for an application, that will use a few different classes. This classes will use one class, that will store all data. I know, when I will use a standard constructor of container class, I'll get tons on nulls, due to different instance of container class.
I've created container class within a singleton, that works, but I wanted to ask if anything could be done better, or if this code follow the best practice.
public class Container 
 private String appName = null;
 private String appOwner = null;
 private Container() 
 System.out.println("Start");
 
 private static class SingletonHolder 
 private final static Container INSTANCE = new Container();
 
 public static Container getInstance() 
 return SingletonHolder.INSTANCE;
 
 public String getAppName() 
 return appName;
 
 public void setAppName(String appName) 
 this.appName = appName;
 
 public String getAppOwner() 
 return appOwner;
 
 public void setAppOwner(String appOwner) 
 this.appOwner = appOwner;
 
Sample class, that will use this container:
public class SecondClass 
 Container ctn = Container.getInstance();
Right now, when I use in main class:
ctn.setAppOwner(owner);
I get a proper value in any other classes, when I call this:
Container ctn = Container.getInstance();
ctn.getAppOwner();
Is that a good approach?
java singleton
I've created working setters/getters for an application, that will use a few different classes. This classes will use one class, that will store all data. I know, when I will use a standard constructor of container class, I'll get tons on nulls, due to different instance of container class.
I've created container class within a singleton, that works, but I wanted to ask if anything could be done better, or if this code follow the best practice.
public class Container 
 private String appName = null;
 private String appOwner = null;
 private Container() 
 System.out.println("Start");
 
 private static class SingletonHolder 
 private final static Container INSTANCE = new Container();
 
 public static Container getInstance() 
 return SingletonHolder.INSTANCE;
 
 public String getAppName() 
 return appName;
 
 public void setAppName(String appName) 
 this.appName = appName;
 
 public String getAppOwner() 
 return appOwner;
 
 public void setAppOwner(String appOwner) 
 this.appOwner = appOwner;
 
Sample class, that will use this container:
public class SecondClass 
 Container ctn = Container.getInstance();
Right now, when I use in main class:
ctn.setAppOwner(owner);
I get a proper value in any other classes, when I call this:
Container ctn = Container.getInstance();
ctn.getAppOwner();
Is that a good approach?
java singleton
edited May 29 at 20:39


Jamalâ¦
30.1k11114225
30.1k11114225
asked Jan 7 at 19:17
Fangir
1
1
 
 
 1
 
 
 
 
 "Is that a good approach? " No, see here: stackoverflow.com/questions/137975/⦠- and here: williamdurand.fr/2013/07/30/from-stupid-to-solid-code
 â Timothy Truckle
 Jan 7 at 19:39
 
 
 
 
 
 
 2
 
 
 
 
 These are all just getting and setting, right? Not much going on really. Not sure if it's even reviewable, as there is nothing.
 â Mast
 Jan 7 at 20:04
 
 
 
add a comment |Â
 
 
 1
 
 
 
 
 "Is that a good approach? " No, see here: stackoverflow.com/questions/137975/⦠- and here: williamdurand.fr/2013/07/30/from-stupid-to-solid-code
 â Timothy Truckle
 Jan 7 at 19:39
 
 
 
 
 
 
 2
 
 
 
 
 These are all just getting and setting, right? Not much going on really. Not sure if it's even reviewable, as there is nothing.
 â Mast
 Jan 7 at 20:04
 
 
 
1
1
"Is that a good approach? " No, see here: stackoverflow.com/questions/137975/⦠- and here: williamdurand.fr/2013/07/30/from-stupid-to-solid-code
â Timothy Truckle
Jan 7 at 19:39
"Is that a good approach? " No, see here: stackoverflow.com/questions/137975/⦠- and here: williamdurand.fr/2013/07/30/from-stupid-to-solid-code
â Timothy Truckle
Jan 7 at 19:39
2
2
These are all just getting and setting, right? Not much going on really. Not sure if it's even reviewable, as there is nothing.
â Mast
Jan 7 at 20:04
These are all just getting and setting, right? Not much going on really. Not sure if it's even reviewable, as there is nothing.
â Mast
Jan 7 at 20:04
add a comment |Â
 3 Answers
 3
 
active
oldest
votes
up vote
1
down vote
There are a couple bad things in the code
First of all, this is weird in many ways:
private Container() 
 System.out.println("Start");
You print out "Start" to the standard output. This basically restrict any usage of this class to have access to a console. What if it is used in a GUI application? What if this is used in a server application?
Also, "Start" what? Whoever read the console will have no clue what is started?
The object is constructed as a static field, and Java did not guarantee when these static constructor are run (they only guarantee it is run before the class methods is run, so it is basically you have a console print that is shown in non-deterministic time.
This is not great too.
public void setAppName(String appName) 
 this.appName = appName;
Whoever got access to the Container object instance can call this method, which means you basically have a global variable that anyone can access. That's a bad idea, because it will makes debugging really difficult.
From these classes, it appears to me that all you needed is to let the app name and app owner initialized once and get access anywhere, you can make that by simply having a Configuration class with a static property.
public class Configuration
 private static String appName;
 private static String appOwner;
 public static void Initialize(String appName, String appOwner)
 
 Configuration.appName = appName;
 Configuration.appOwner = appOwner;
 
 public static String AppName() return Configuration.appName; 
 public static String AppOwner() return Configuration.appOwner; 
That would be it, simple and clear.
 
 
 
 
 
 
 Thanks for the reply. Regarding the- System.out.printl- there gonna be log4j in this place later on - right now I don't wan't to implement it, before I'll set up a logic. Right now I'm trying your approach, it's really interesting, and I think, I'll like it. In this Configuration class, there will be a lot of variables - is that a good practice to put here ie.- public static void Initialize(String appName, String appOwner, String n1 ... String n30)?
 â Fangir
 Jan 8 at 6:44
 
 
 
 
add a comment |Â
up vote
0
down vote
The technique is pretty standard; an alternative:
public enum Container 
 INSTANCE;
 ...
However setters can be called more than once, and even concurrently; so that is an area still to be tackled.
The chance of using immutable objects with a once-only initialisation, and possibly only having a
public static final String APP_NAME;
will be given away.
The reason is, the concentration on the data model - of say a Model-View-Controller paradigm.
My proposal: You could have a singleton Controller, the Application(Controller) or such. This main controller could hold the model, more than one container. Access would by MVC go via the controller.
This allows initialisation of some container with values, and specific work oriented access to the data model. (Several data, states.)
This will be much more satisfying for a developer, as now you start with many getters and setters, and with a controller layer, much boiler plate code falls away. Ideally only business logic operations remain.
add a comment |Â
up vote
0
down vote
First off I would like to point out that "setters" are usually called mutators and "getters" are called accessors; however that is not usually important in practice(In my experience so far).
As already mentioned, the following command is pretty obsolete and is not required.
System.out.println("Start");
Also a quicker way to initialize an object of this class may be to use an override constructor below the first constructor as such:
private String appName;
private String appOwner;
public Container() 
 appName = null;
 appOwner = null;
public Container(int appName, int appOwner)
 this.appName = appName;
 this.appOwner = appOwner;
This will save you the time of having to call 2 mutator or setter methods every time you create a new instance of the object.
add a comment |Â
 3 Answers
 3
 
active
oldest
votes
 3 Answers
 3
 
active
oldest
votes
active
oldest
votes
active
oldest
votes
up vote
1
down vote
There are a couple bad things in the code
First of all, this is weird in many ways:
private Container() 
 System.out.println("Start");
You print out "Start" to the standard output. This basically restrict any usage of this class to have access to a console. What if it is used in a GUI application? What if this is used in a server application?
Also, "Start" what? Whoever read the console will have no clue what is started?
The object is constructed as a static field, and Java did not guarantee when these static constructor are run (they only guarantee it is run before the class methods is run, so it is basically you have a console print that is shown in non-deterministic time.
This is not great too.
public void setAppName(String appName) 
 this.appName = appName;
Whoever got access to the Container object instance can call this method, which means you basically have a global variable that anyone can access. That's a bad idea, because it will makes debugging really difficult.
From these classes, it appears to me that all you needed is to let the app name and app owner initialized once and get access anywhere, you can make that by simply having a Configuration class with a static property.
public class Configuration
 private static String appName;
 private static String appOwner;
 public static void Initialize(String appName, String appOwner)
 
 Configuration.appName = appName;
 Configuration.appOwner = appOwner;
 
 public static String AppName() return Configuration.appName; 
 public static String AppOwner() return Configuration.appOwner; 
That would be it, simple and clear.
 
 
 
 
 
 
 Thanks for the reply. Regarding the- System.out.printl- there gonna be log4j in this place later on - right now I don't wan't to implement it, before I'll set up a logic. Right now I'm trying your approach, it's really interesting, and I think, I'll like it. In this Configuration class, there will be a lot of variables - is that a good practice to put here ie.- public static void Initialize(String appName, String appOwner, String n1 ... String n30)?
 â Fangir
 Jan 8 at 6:44
 
 
 
 
add a comment |Â
up vote
1
down vote
There are a couple bad things in the code
First of all, this is weird in many ways:
private Container() 
 System.out.println("Start");
You print out "Start" to the standard output. This basically restrict any usage of this class to have access to a console. What if it is used in a GUI application? What if this is used in a server application?
Also, "Start" what? Whoever read the console will have no clue what is started?
The object is constructed as a static field, and Java did not guarantee when these static constructor are run (they only guarantee it is run before the class methods is run, so it is basically you have a console print that is shown in non-deterministic time.
This is not great too.
public void setAppName(String appName) 
 this.appName = appName;
Whoever got access to the Container object instance can call this method, which means you basically have a global variable that anyone can access. That's a bad idea, because it will makes debugging really difficult.
From these classes, it appears to me that all you needed is to let the app name and app owner initialized once and get access anywhere, you can make that by simply having a Configuration class with a static property.
public class Configuration
 private static String appName;
 private static String appOwner;
 public static void Initialize(String appName, String appOwner)
 
 Configuration.appName = appName;
 Configuration.appOwner = appOwner;
 
 public static String AppName() return Configuration.appName; 
 public static String AppOwner() return Configuration.appOwner; 
That would be it, simple and clear.
 
 
 
 
 
 
 Thanks for the reply. Regarding the- System.out.printl- there gonna be log4j in this place later on - right now I don't wan't to implement it, before I'll set up a logic. Right now I'm trying your approach, it's really interesting, and I think, I'll like it. In this Configuration class, there will be a lot of variables - is that a good practice to put here ie.- public static void Initialize(String appName, String appOwner, String n1 ... String n30)?
 â Fangir
 Jan 8 at 6:44
 
 
 
 
add a comment |Â
up vote
1
down vote
up vote
1
down vote
There are a couple bad things in the code
First of all, this is weird in many ways:
private Container() 
 System.out.println("Start");
You print out "Start" to the standard output. This basically restrict any usage of this class to have access to a console. What if it is used in a GUI application? What if this is used in a server application?
Also, "Start" what? Whoever read the console will have no clue what is started?
The object is constructed as a static field, and Java did not guarantee when these static constructor are run (they only guarantee it is run before the class methods is run, so it is basically you have a console print that is shown in non-deterministic time.
This is not great too.
public void setAppName(String appName) 
 this.appName = appName;
Whoever got access to the Container object instance can call this method, which means you basically have a global variable that anyone can access. That's a bad idea, because it will makes debugging really difficult.
From these classes, it appears to me that all you needed is to let the app name and app owner initialized once and get access anywhere, you can make that by simply having a Configuration class with a static property.
public class Configuration
 private static String appName;
 private static String appOwner;
 public static void Initialize(String appName, String appOwner)
 
 Configuration.appName = appName;
 Configuration.appOwner = appOwner;
 
 public static String AppName() return Configuration.appName; 
 public static String AppOwner() return Configuration.appOwner; 
That would be it, simple and clear.
There are a couple bad things in the code
First of all, this is weird in many ways:
private Container() 
 System.out.println("Start");
You print out "Start" to the standard output. This basically restrict any usage of this class to have access to a console. What if it is used in a GUI application? What if this is used in a server application?
Also, "Start" what? Whoever read the console will have no clue what is started?
The object is constructed as a static field, and Java did not guarantee when these static constructor are run (they only guarantee it is run before the class methods is run, so it is basically you have a console print that is shown in non-deterministic time.
This is not great too.
public void setAppName(String appName) 
 this.appName = appName;
Whoever got access to the Container object instance can call this method, which means you basically have a global variable that anyone can access. That's a bad idea, because it will makes debugging really difficult.
From these classes, it appears to me that all you needed is to let the app name and app owner initialized once and get access anywhere, you can make that by simply having a Configuration class with a static property.
public class Configuration
 private static String appName;
 private static String appOwner;
 public static void Initialize(String appName, String appOwner)
 
 Configuration.appName = appName;
 Configuration.appOwner = appOwner;
 
 public static String AppName() return Configuration.appName; 
 public static String AppOwner() return Configuration.appOwner; 
That would be it, simple and clear.
edited Jan 8 at 6:20
answered Jan 8 at 0:54
Andrew Au
3388
3388
 
 
 
 
 
 
 Thanks for the reply. Regarding the- System.out.printl- there gonna be log4j in this place later on - right now I don't wan't to implement it, before I'll set up a logic. Right now I'm trying your approach, it's really interesting, and I think, I'll like it. In this Configuration class, there will be a lot of variables - is that a good practice to put here ie.- public static void Initialize(String appName, String appOwner, String n1 ... String n30)?
 â Fangir
 Jan 8 at 6:44
 
 
 
 
add a comment |Â
 
 
 
 
 
 
 Thanks for the reply. Regarding the- System.out.printl- there gonna be log4j in this place later on - right now I don't wan't to implement it, before I'll set up a logic. Right now I'm trying your approach, it's really interesting, and I think, I'll like it. In this Configuration class, there will be a lot of variables - is that a good practice to put here ie.- public static void Initialize(String appName, String appOwner, String n1 ... String n30)?
 â Fangir
 Jan 8 at 6:44
 
 
 
 
Thanks for the reply. Regarding the
System.out.printl - there gonna be log4j in this place later on - right now I don't wan't to implement it, before I'll set up a logic. Right now I'm trying your approach, it's really interesting, and I think, I'll like it. In this Configuration class, there will be a lot of variables - is that a good practice to put here ie. public static void Initialize(String appName, String appOwner, String n1 ... String n30) ?â Fangir
Jan 8 at 6:44
Thanks for the reply. Regarding the
System.out.printl - there gonna be log4j in this place later on - right now I don't wan't to implement it, before I'll set up a logic. Right now I'm trying your approach, it's really interesting, and I think, I'll like it. In this Configuration class, there will be a lot of variables - is that a good practice to put here ie. public static void Initialize(String appName, String appOwner, String n1 ... String n30) ?â Fangir
Jan 8 at 6:44
add a comment |Â
up vote
0
down vote
The technique is pretty standard; an alternative:
public enum Container 
 INSTANCE;
 ...
However setters can be called more than once, and even concurrently; so that is an area still to be tackled.
The chance of using immutable objects with a once-only initialisation, and possibly only having a
public static final String APP_NAME;
will be given away.
The reason is, the concentration on the data model - of say a Model-View-Controller paradigm.
My proposal: You could have a singleton Controller, the Application(Controller) or such. This main controller could hold the model, more than one container. Access would by MVC go via the controller.
This allows initialisation of some container with values, and specific work oriented access to the data model. (Several data, states.)
This will be much more satisfying for a developer, as now you start with many getters and setters, and with a controller layer, much boiler plate code falls away. Ideally only business logic operations remain.
add a comment |Â
up vote
0
down vote
The technique is pretty standard; an alternative:
public enum Container 
 INSTANCE;
 ...
However setters can be called more than once, and even concurrently; so that is an area still to be tackled.
The chance of using immutable objects with a once-only initialisation, and possibly only having a
public static final String APP_NAME;
will be given away.
The reason is, the concentration on the data model - of say a Model-View-Controller paradigm.
My proposal: You could have a singleton Controller, the Application(Controller) or such. This main controller could hold the model, more than one container. Access would by MVC go via the controller.
This allows initialisation of some container with values, and specific work oriented access to the data model. (Several data, states.)
This will be much more satisfying for a developer, as now you start with many getters and setters, and with a controller layer, much boiler plate code falls away. Ideally only business logic operations remain.
add a comment |Â
up vote
0
down vote
up vote
0
down vote
The technique is pretty standard; an alternative:
public enum Container 
 INSTANCE;
 ...
However setters can be called more than once, and even concurrently; so that is an area still to be tackled.
The chance of using immutable objects with a once-only initialisation, and possibly only having a
public static final String APP_NAME;
will be given away.
The reason is, the concentration on the data model - of say a Model-View-Controller paradigm.
My proposal: You could have a singleton Controller, the Application(Controller) or such. This main controller could hold the model, more than one container. Access would by MVC go via the controller.
This allows initialisation of some container with values, and specific work oriented access to the data model. (Several data, states.)
This will be much more satisfying for a developer, as now you start with many getters and setters, and with a controller layer, much boiler plate code falls away. Ideally only business logic operations remain.
The technique is pretty standard; an alternative:
public enum Container 
 INSTANCE;
 ...
However setters can be called more than once, and even concurrently; so that is an area still to be tackled.
The chance of using immutable objects with a once-only initialisation, and possibly only having a
public static final String APP_NAME;
will be given away.
The reason is, the concentration on the data model - of say a Model-View-Controller paradigm.
My proposal: You could have a singleton Controller, the Application(Controller) or such. This main controller could hold the model, more than one container. Access would by MVC go via the controller.
This allows initialisation of some container with values, and specific work oriented access to the data model. (Several data, states.)
This will be much more satisfying for a developer, as now you start with many getters and setters, and with a controller layer, much boiler plate code falls away. Ideally only business logic operations remain.
answered Jan 8 at 8:26


Joop Eggen
987612
987612
add a comment |Â
add a comment |Â
up vote
0
down vote
First off I would like to point out that "setters" are usually called mutators and "getters" are called accessors; however that is not usually important in practice(In my experience so far).
As already mentioned, the following command is pretty obsolete and is not required.
System.out.println("Start");
Also a quicker way to initialize an object of this class may be to use an override constructor below the first constructor as such:
private String appName;
private String appOwner;
public Container() 
 appName = null;
 appOwner = null;
public Container(int appName, int appOwner)
 this.appName = appName;
 this.appOwner = appOwner;
This will save you the time of having to call 2 mutator or setter methods every time you create a new instance of the object.
add a comment |Â
up vote
0
down vote
First off I would like to point out that "setters" are usually called mutators and "getters" are called accessors; however that is not usually important in practice(In my experience so far).
As already mentioned, the following command is pretty obsolete and is not required.
System.out.println("Start");
Also a quicker way to initialize an object of this class may be to use an override constructor below the first constructor as such:
private String appName;
private String appOwner;
public Container() 
 appName = null;
 appOwner = null;
public Container(int appName, int appOwner)
 this.appName = appName;
 this.appOwner = appOwner;
This will save you the time of having to call 2 mutator or setter methods every time you create a new instance of the object.
add a comment |Â
up vote
0
down vote
up vote
0
down vote
First off I would like to point out that "setters" are usually called mutators and "getters" are called accessors; however that is not usually important in practice(In my experience so far).
As already mentioned, the following command is pretty obsolete and is not required.
System.out.println("Start");
Also a quicker way to initialize an object of this class may be to use an override constructor below the first constructor as such:
private String appName;
private String appOwner;
public Container() 
 appName = null;
 appOwner = null;
public Container(int appName, int appOwner)
 this.appName = appName;
 this.appOwner = appOwner;
This will save you the time of having to call 2 mutator or setter methods every time you create a new instance of the object.
First off I would like to point out that "setters" are usually called mutators and "getters" are called accessors; however that is not usually important in practice(In my experience so far).
As already mentioned, the following command is pretty obsolete and is not required.
System.out.println("Start");
Also a quicker way to initialize an object of this class may be to use an override constructor below the first constructor as such:
private String appName;
private String appOwner;
public Container() 
 appName = null;
 appOwner = null;
public Container(int appName, int appOwner)
 this.appName = appName;
 this.appOwner = appOwner;
This will save you the time of having to call 2 mutator or setter methods every time you create a new instance of the object.
answered Jan 11 at 2:38
Sean
1234
1234
add a comment |Â
add a comment |Â
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcodereview.stackexchange.com%2fquestions%2f184527%2fjava-singleton-getter-setter%23new-answer', 'question_page');
);
Post as a guest
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
1
"Is that a good approach? " No, see here: stackoverflow.com/questions/137975/⦠- and here: williamdurand.fr/2013/07/30/from-stupid-to-solid-code
â Timothy Truckle
Jan 7 at 19:39
2
These are all just getting and setting, right? Not much going on really. Not sure if it's even reviewable, as there is nothing.
â Mast
Jan 7 at 20:04