Thursday, July 23, 2009
Java Time and UTC
Java does have a date type that is truly time zone ignorant: long. It is the time in milliseconds since January 1, 1970 UTC. It is the value you get when you say System.currentTimeMillis. You can convert that for display, to local time, server time, UTC, or any other time zone you want, when you want to display it. java.util.Date and java.sql.Date and java.sql.Time all wrap long, and they contain no time zone information at all. If you call toString(), it will format the time into a string using the local time zone, but toString() is intended primarily as a diagnostic tool. Most other methods on those classes are deprecated because date/time localization is not a trivial issue: they don't really work. java.util.Calendar is currently the preferred way to deal with date/time localization in Java. Use java.text.DateFormat for more flexible capabilities (it uses java.util.Calendar internally to do its work).
Friday, July 10, 2009
When Windows Explorer Acts Buggy
Recently, at work, my Windows XP machine started acting very strange: Windows Explorer took forever to list directories and appeared to be freezing up on occasion. When, after several re-boots the problem remained persistent I consulted with my Google friend.
The solution was relatively simple.
delete C:\Documents and Settings\\Local Settings\Application Data\Microsoft\Windows
(or you could simply rename it if you don't like the word delete)
However, there is one caveat: you need to sign in as a different user with local-admin rights in order to delete this file because you can't delete this file as the current user.
Hope this helps someone.
The solution was relatively simple.
delete C:\Documents and Settings\
(or you could simply rename it if you don't like the word delete)
However, there is one caveat: you need to sign in as a different user with local-admin rights in order to delete this file because you can't delete this file as the current user.
Hope this helps someone.
Tuesday, June 16, 2009
When Explicitly Initializing Class Variables to null Matters
You can't just willy-nilly do anything in Java because it 'looks good' - aside from formatting of course - and even certain ways of formatting can have an effect on code initialization, such as ordering of class/instance variables and static initialization blocks.
Here is an example where understanding what actually happens when an instance variable is explicitly initialized to null will cause a null-pointer to occur even though it is initialized to a non-null value in an implemented abstract method that is called by the super constructor.
In the following example, the abstract class has one abstract method, doConcreteStuff1, that is intended to be invoked in the constructor of the same class: concrete classes need only implement doConcreteStuff1(). Here we have explicitly set instance variables 'one' and 'two' to null and we initialize them in the implemented doConcreteStuff() method.
What do you think will happen when the code is executed?
When the code is executed the following occurs:
B:One is one
B:Two is two
Exception in thread "main" java.lang.NullPointerException
at base.InstanceVarNull$ConcreteInstanceVarNull.(InstanceVarNull.java:16)
at base.InstanceVarNull.main(InstanceVarNull.java:28)
:banghead: UGhhh!! A null-pointer!!!!
Is that what you expected? After all, we did initialize them to non-null values, but it appears that they were overwritten back to null! What gives?
Let's demonstrate another example. I'll remove the explicit null initialization from the instance variables.
What do you think will happen this time when the new code is executed?
When the code is executed the following occurs:
B:One is one
B:Two is two
A:One is one
A:Two is two
No null-pointer!!! :eek:
The question here is, why?
By explicitly assigning null to the instance variables (in example 1), the compiler will insert the assignment in the constructor of the concrete class and due to the order of operations, doConcreteStuff1() will indeed get executed BEFORE this assignment. So we will see 2 statements being printed, but after that the concrete class will then initialize and re-assign those variables to null.
However, in the second example, we DO NOT explicitly assign null to the instance variables and the compiler does not assign them as null in the constructor. So when we execute example 2, the only assignment for those variables occurs in the doConcreteStuff1() method, and we have NO null-pointers.
Check out the byte-code of each example if you don't believe me.
Cheers and happy coding! :beerchug:
I thought I would add the de-compiled class files to prove my claim:
Here is the generated class file with null explicitly set (example 1, above), more specifically I show the constructor:
Note lines 5 and 10.
, and here is the generated class file with null NOT explicitly set (example 2, above), more specifically I show the constructor:
Note that the null assignment DOES NOT occur in the constructor as it does above, which is the reason why the values do not get overridden and hence no null-pointer!!!! :jumpingjoy: :jumpingjoy:
Here is an example where understanding what actually happens when an instance variable is explicitly initialized to null will cause a null-pointer to occur even though it is initialized to a non-null value in an implemented abstract method that is called by the super constructor.
In the following example, the abstract class has one abstract method, doConcreteStuff1, that is intended to be invoked in the constructor of the same class: concrete classes need only implement doConcreteStuff1(). Here we have explicitly set instance variables 'one' and 'two' to null and we initialize them in the implemented doConcreteStuff() method.
What do you think will happen when the code is executed?
When the code is executed the following occurs:
B:One is one
B:Two is two
Exception in thread "main" java.lang.NullPointerException
at base.InstanceVarNull$ConcreteInstanceVarNull.
at base.InstanceVarNull.main(InstanceVarNull.java:28)
:banghead: UGhhh!! A null-pointer!!!!
Is that what you expected? After all, we did initialize them to non-null values, but it appears that they were overwritten back to null! What gives?
Let's demonstrate another example. I'll remove the explicit null initialization from the instance variables.
What do you think will happen this time when the new code is executed?
When the code is executed the following occurs:
B:One is one
B:Two is two
A:One is one
A:Two is two
No null-pointer!!! :eek:
The question here is, why?
By explicitly assigning null to the instance variables (in example 1), the compiler will insert the assignment in the constructor of the concrete class and due to the order of operations, doConcreteStuff1() will indeed get executed BEFORE this assignment. So we will see 2 statements being printed, but after that the concrete class will then initialize and re-assign those variables to null.
However, in the second example, we DO NOT explicitly assign null to the instance variables and the compiler does not assign them as null in the constructor. So when we execute example 2, the only assignment for those variables occurs in the doConcreteStuff1() method, and we have NO null-pointers.
Check out the byte-code of each example if you don't believe me.
Cheers and happy coding! :beerchug:
I thought I would add the de-compiled class files to prove my claim:
Here is the generated class file with null explicitly set (example 1, above), more specifically I show the constructor:
Note lines 5 and 10.
, and here is the generated class file with null NOT explicitly set (example 2, above), more specifically I show the constructor:
Note that the null assignment DOES NOT occur in the constructor as it does above, which is the reason why the values do not get overridden and hence no null-pointer!!!! :jumpingjoy: :jumpingjoy:
Subscribe to:
Posts (Atom)