2010-04-26 17 views
1

我正在使用glibs函数将历元时间转换为字符串,如下所示。
但每次它给我一些随机时间。Glib将历元时间转换为字符串

//Convert Time in string. 
GDate *date = g_date_new_julian(timestampsecs); 
gchar date_string[50]; 
g_date_strftime(date_string, 50, (const gchar*)"%a, %I:%M %p", (const GDate*)date); 
printf("Date String [%s]\n", date_string); 

为什么会发生这种情况?我错过了什么?

谢谢,
PP。

UPDATE:

如所述我试图与setlocale(LC_ALL, "");以下为输出,
它是相同的我使用setlocale之前得到。

(MyTestApp:7747): GLib-WARNING **: 
OOPS julian: 1272279703 computed dmy: 66 4293563716 187 
Date String Tik_INDEX[1] [1272279703] --> [Tue, 12:00 AM] 

(MyTestApp:7747): GLib-WARNING **: 
OOPS julian: 1272279717 computed dmy: 80 4293563716 187 
Date String Tik_INDEX[2] [1272279717] --> [Tue, 12:00 AM] 

(MyTestApp:7747): GLib-WARNING **: 
OOPS julian: 1272279720 computed dmy: 53 4293563717 187 
Date String Tik_INDEX[3] [1272279720] --> [Fri, 12:00 AM] 

(MyTestApp:7747): GLib-WARNING **: 
OOPS julian: 1272279721 computed dmy: 54 4293563717 187 
Date String Tik_INDEX[4] [1272279721] --> [Sat, 12:00 AM] 

(MyTestApp:7747): GLib-WARNING **: 
OOPS julian: 1272279721 computed dmy: 54 4293563717 187 
Date String Tik_INDEX[5] [1272279721] --> [Sat, 12:00 AM] 

(MyTestApp:7747): GLib-WARNING **: 
OOPS julian: 1272279722 computed dmy: 55 4293563717 187 
Date String Tik_INDEX[6] [1272279722] --> [Sun, 12:00 AM] 

(MyTestApp:7747): GLib-WARNING **: 
OOPS julian: 1272279723 computed dmy: 56 4293563717 187 
Date String Tik_INDEX[7] [1272279723] --> [Mon, 12:00 AM] 

(MyTestApp:7747): GLib-WARNING **: 
OOPS julian: 1272279724 computed dmy: 57 4293563717 187 
Date String Tik_INDEX[8] [1272279724] --> [Tue, 12:00 AM] 

回答

1

你可能想打电话setlocale()第一 “LC_ALL” should do itPOSIX也应该工作,不确定关于C

g_date_strftime()受语言环境设置的影响。它也很好地存储g_date_strftime()的结果,或其他填充静态缓冲区的结果。您需要知道实际打印到缓冲区的字节数。

+0

感谢您的回复, 请通过问题的更新部分。 – User7723337 2010-04-26 11:24:58

相关问题