I have great experience in IT over 12 years: front / back - ends, mobile, system administration and deployment cycle. I implement effective and great software products.
Could you provide the practical example with NullBoss?
Cause the current example is not like dummy date, that can be used as mock. But the example which is far from reality, correct me if I wrong.
I think the whole idea of using NullObject is taken from Option type, which holds None or Some. When they is no null you don't think it exists. E.g. while Some holds a real not null value, which can be mapped, None always returns None. This approach is called "Railway programming".
I have great experience in IT over 12 years: front / back - ends, mobile, system administration and deployment cycle. I implement effective and great software products.
As I know, the pattern was a long time before Optionals (some, none).
And what author proposes – it’s a big difference from it.
Using optionals you stop the execution flow, while the topic about redundant objects creation.
Grumpy old fart that throws up a little every time he sees someone being passionate about some javascript lib. Tech agnostic. If it bleeds, I can kill -9 it.
Like in all OOP, you still need to make the decision on which class to create somewhere. What you gain by taking the decision at a higher-up place is the ability to avoid this decision in all other places.
For further actions, you may consider blocking this person and/or reporting abuse
Hi James, how do you instantiate the NullBoss class? I reckon it still needs to do the null check in the first place, doesn't it?
The
NullBossdoesn't do any null checking because it replaces the concept of null altogether.Usually with kind of pattern, you would have a factory of some kind create your objects for you.
Does that help?
Could you provide the practical example with
NullBoss?Cause the current example is not like dummy date, that can be used as mock. But the example which is far from reality, correct me if I wrong.
I think the whole idea of using NullObject is taken from Option type, which holds None or Some. When they is no
nullyou don't think it exists. E.g. while Some holds a real not null value, which can be mapped, None always returns None. This approach is called "Railway programming".nullis avoided and the program doesn't crash. Just different way of thinking when there is no null.As I know, the pattern was a long time before Optionals (some, none).
And what author proposes – it’s a big difference from it.
Using optionals you stop the execution flow, while the topic about redundant objects creation.
2 examples I've seen in Minecraft:
Air blocks - they are blocks like any other, rather than nulls to represent a block not being present in a location
Also added in the last few versions (replacing null) - "Empty" item stacks - there is a singleton "ItemStack.EMPTY" and a method "ItemStack#isEmpty()"
Like in all OOP, you still need to make the decision on which class to create somewhere. What you gain by taking the decision at a higher-up place is the ability to avoid this decision in all other places.