簡體   English   中英

“本地時間”功能在第二次調用時崩潰

[英]'localtime' function crashes on second call

因此,我編寫了下一個函數:

void actualizetime(){
  puts("actualizetime called"); //debugging purposes.
  time_t rawtime;
  puts("static time_t defined"); //debugging purposes.
  struct tm *timeinfo;
  puts("struct tm * defined"); //debugging purposes.
  time(&rawtime);
  puts("time function called"); //debugging purposes.
  timeinfo = localtime(&rawtime);
  puts("timeinfo has localtime"); //debugging purposes.

  actualtime.year = timeinfo->tm_year + 1900;
  actualtime.month = timeinfo->tm_mon;
  actualtime.day = timeinfo->tm_mday;
  actualtime.hour = timeinfo->tm_hour;
  actualtime.min = timeinfo->tm_min;
  actualtime.sec = timeinfo->tm_sec;
}

事實是,此功能僅可運行一次。 第二次調用該函數, timeinfo = localtime(&rawtime); 崩潰。 怎么了 而且,我該如何解決?

我認為actualtime結構並不重要,但是無論如何:

struct {
  int year;
  int month;
  int day;

  int hour;
  int min;
  int sec;
} actualtime;

編輯

完整程序(僅Linux):

警告 :要運行此程序,您必須是root用戶,並且在根文件系統上具有一個名為/pragma/regfiles/

#include<sys/stat.h>
#include<stdlib.h>
#include<stdio.h>
#include<time.h>

void actualizetime(void);
void openregfile(void);
void closeregfile(void);
void addreg(char *,char *);
void terminate(void);

char *months[] = {"Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"};

FILE *regfile;

struct {
  int year;
  int month;
  int day;

  int hour;
  int min;
  int sec;
} actualtime;

void actualizetime(){
  puts("-actualizetime called"); //debugging purposes.
  time_t rawtime;
  puts("-static time_t defined"); //debugging purposes.
  struct tm *timeinfo;
  puts("-struct tm * defined"); //debugging purposes.
  time(&rawtime);
  puts("-time function called"); //debugging purposes.
  timeinfo = localtime(&rawtime);
  puts("-timeinfo has localtime"); //debugging purposes.

  actualtime.year = timeinfo->tm_year + 1900;
  actualtime.month = timeinfo->tm_mon;
  actualtime.day = timeinfo->tm_mday;
  actualtime.hour = timeinfo->tm_hour;
  actualtime.min = timeinfo->tm_min;
  actualtime.sec = timeinfo->tm_sec;
}

void openregfile(void){
  char route[64];
  struct stat *st;

  if(!route){
    puts("Error initializing files");
    exit(1);
  }

  actualizetime();

  sprintf(route, "/pragma/regfiles/%04d/", actualtime.year);
  if(stat(route, st) < 0){
    if(mkdir(route, 0600) < 0){
      puts("ERROR: cannot create directory for regs files! (1)");
      exit(1);
    }
  }

  sprintf(route, "/pragma/regfiles/%04d/%s", actualtime.year, months[actualtime.month]);
  if(stat(route, st) < 0){
    if(mkdir(route, 0600) < 0){
      puts("ERROR: cannot create directory for regs files! (2)");
      exit(1);
    }
  }

  sprintf(route, "/pragma/regfiles/%04d/%s/%02d.reg", actualtime.year, months[actualtime.month], actualtime.day);
  if((regfile = fopen(route, "a")) == NULL){
    puts("ERROR: cannot create reg file!");
    exit(1);
  }
  addreg("log", "reg start");
}

void closeregfile(){
  addreg("log", "reg stop");
  fclose(regfile);
}

void addreg(char *label,char *msg){
  puts("-before actualize time");  //debugging purposes.
  actualizetime();
  puts("-after actualize time");  //debugging purposes.
  printf("%d%d%d", actualtime.hour, actualtime.min, actualtime.sec);
  fprintf(regfile, "[%s]:%04d%s%02d_%02d%02d%02d %s\n", label, actualtime.year, months[actualtime.month], actualtime.day, actualtime.hour, actualtime.min, actualtime.sec, msg);
  fflush(regfile);
}






int main(void){
  openregfile();

  //Do something

  terminate();
  return 0;
}

void terminate(void){
  closeregfile();
  puts("Terminating...");
}

發布的(編輯的)代碼無法完全編譯

建議始終在啟用所有警告的情況下進行編譯。

然后,您將看到以下兩個消息:

...c:49:6 warning: the addres of 'route' will always be evaluated as 'true' [-Waddress]

if(!route){

...c:57:10: warning 'st' is used unitialized in this function [-Wuninitalized]

if(stat(route, st) < 0){

強烈建議在考慮嘗試運行程序之前,先解決編譯問題。

這會導致不確定的行為:

struct stat *st;
if(stat(route, st) < 0){

您正在將未初始化的變量st傳遞給庫函數,這會導致未定義的行為。

閱讀有關stat手冊頁會告訴您,應該提供一個指向已經存在的緩沖區的指針,然后stat函數將被填充。

例如:

struct stat st = { 0 };     // good practice to zero-initialize
if ( stat(route, &st) < 0 ) {

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM