On 04/02/2011 06:31 PM, Boyd Stephen Smith Jr. wrote:
In<4d96a8c3.9080...@cox.net>, Ron Johnson wrote:
I've always thought that Unix Time is *incredibly stupid* (who the heck
says "Fri Apr 1 23:27:41 CDT 2011"?)
and *monumentally shortsighted*
(did nothing happen before 01-Jan-1970?).
What makes you say this is UNIX time? The UNIX standard provides many ways of
displaying a time, and AFAIK, doesn't really prefer any particular string
format.
Because that's traditionally how ls presents the file date.
For me, UNIX time is nanoseconds from Epoch. The time_t and clock_t types are
The Epoch is still 01-Jan-1970.
allowed to be signed and any reasonable size.
Which is still 32 bits on 32-bit Linux.
$ cat time_t.c
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main (int argc, char **argv )
{
printf("bits in time_t = %d\n", sizeof(time_t) * 8);
printf("bits in clock_t = %d\n", sizeof(clock_t) * 8);
}
$ gcc time_t.c
$ ./a.out
bits in time_t = 32
bits in clock_t = 32
The timespec structure
specifically records nanosecond and interprets a time_t as seconds. The
clock_t type was "always" in microseconds in SUSv2, but even then there was
warning that it might change.
Which breaks binary compatibility.
Traditionally, UNIX-like systems have used a 32-bit signed time_t, but I'm
pretty sure all the *BSDs (including Mac OS X) and the Linux kernel have moved
beyond that. I'm not sure about AIX and Solaris. I'm pretty sure there won't
be anymore HP-UX.
--
"Neither the wisest constitution nor the wisest laws will secure
the liberty and happiness of a people whose manners are universally
corrupt."
Samuel Adams, essay in The Public Advertiser, 1749
--
To UNSUBSCRIBE, email to debian-user-requ...@lists.debian.org
with a subject of "unsubscribe". Trouble? Contact listmas...@lists.debian.org
Archive: http://lists.debian.org/4d97bccb.3090...@cox.net