編輯:感謝迄今爲止的答案,至少我現在可以編譯它,但我仍然得到一個分割錯誤。什麼是導致此C代碼中的段錯誤錯誤?
編譯我用下面的一行:
gcc -g -O0 -I../include -L../ test.c -static -lrt
源代碼如下:
#include <sys/time.h>
#include <time.h>
#include <stdio.h>
struct timespec *diff(struct timespec *start, struct timespec *end);
int main()
{
struct timespec time1, time2;
int i;
int temp = 0;
clock_gettime(CLOCK_PROCESS_CPUTIME_ID, &time1);
for (i = 0; i< 242000000; i++)
temp+=temp;
clock_gettime(CLOCK_PROCESS_CPUTIME_ID, &time2);
printf("sec: %d, nsec: %f",diff(&time1,&time2)->tv_sec, diff(&time1,&time2)->tv_nsec);
//cout<<diff(time1,time2).tv_sec<<":"<<diff(time1,time2).tv_nsec<<endl;
return 0;
}
struct timespec *diff(struct timespec *start, struct timespec *end)
{
struct timespec *temp;
if ((end->tv_nsec-start->tv_nsec)<0) {
temp->tv_sec = end->tv_sec-start->tv_sec-1;
temp->tv_nsec = 1000000000+end->tv_nsec-start->tv_nsec;
} else {
temp->tv_sec = end->tv_sec-start->tv_sec;
temp->tv_nsec = end->tv_nsec-start->tv_nsec;
}
return temp;
}
我現在得到以下警告:
test.c: In function ‘main’:
test.c:17: warning: format ‘%d’ expects type ‘int’, but argument 2 has type ‘__time_t’
test.c:17: warning: format ‘%f’ expects type ‘double’, but argument 3 has type ‘long int’
分段故障肯定是由我處理結構造成的。這是相當長一段時間前,我最後不得不處理。C ....
非常感謝, 馬庫斯
嘗試運行'gcc -C -E foo.c'並查看timespec結構是如何定義的,如果它定義的話。至少在Cygwin上,我只有'timeval',沒有'timespec'。 – csl 2010-01-27 15:03:03
也添加到編譯器選項。 GCC會告訴你問題是什麼:) – 2010-01-27 16:40:10