Just wait until 2039 when the the unix timer variable overflows. Plenty of
work to do to handle that.
First of all, the problem will occur early in 2038, not in 2039.
And not just on Unix... This will affect OS/400 and Windows as well. For
example, the dates/times in the IFS are all stored using a 32-bit integer.
Many of the router & firewall boxes used in networking use these as well.
I imagine there are tons of other electronics with this logic embedded in
them.
I've got lots of RPG programs that use this logic, so it's not limited to
C. Some of them have been written within the past week!
FWIW, the problem isn't as difficult to fix as it sounds. All you have to
do is switch to use an unsigned integer to store your timestamp and you'll
postpone the problem until 2106. Since, bitwise, any value from 1970 -
2037 will be identical in a signed and unsigned integer, the routines can
be kept backward compable with ease.
Obviously, it's a good practice to store your dates & times in a format
that will last longer, like using a separate integer for date from the one
for time. Or using a character field, like we typically do...
As an Amazon Associate we earn from qualifying purchases.
This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact
[javascript protected email address].
Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.