Сведения о вопросе

ЧОВИД

09:09, 2nd August, 2020

Теги

Вывод метки времени компиляции в исполняемом файле Visual C++?

Просмотров: 599   Ответов: 6

Как я могу вставить информацию о компиляции timestamp в исполняемый файл, который я строю с помощью Visual C++ 2005? Я хочу иметь возможность выводить что-то подобное, когда я выполняю программу:

Эта сборка XXXX была скомпилирована в dd-mm-yy, hh:mm.

где дата и время отражают время, когда был построен проект. Они не должны изменяться при каждом последующем вызове программы, если только она не будет перекомпилирована.



  Сведения об ответе

LIZA

08:25, 13th August, 2020

Хотя это и не ваш точный формат, DATE будет иметь формат Mmm dd yyyy, а TIME -формат hh:mm:ss. Вы можете создать такую строку и использовать ее в любой рутине печати, которая имеет для вас смысл:

const char *buildString = "This build XXXX was compiled at " __DATE__ ", " __TIME__ ".";

(Обратите внимание на другой ответ: TIMESTAMP только выплевывает дату/время модификации исходного файла, а не сборки date/time.)


  Сведения об ответе

padenie

06:20, 28th August, 2020

__DATE__ 
__TIME__

они предопределены как часть стандартов для C99, поэтому должны быть доступны вам. Они запускаются один раз с препроцессором.


  Сведения об ответе

prince

23:15, 22nd August, 2020

Что ж... для Visual C++ существует встроенный символ под названием __ImageBase . Конкретно:

EXTERN_C IMAGE_DOS_HEADER __ImageBase;

Вы можете проверить это во время выполнения, чтобы определить timestamp в заголовке PE:

const IMAGE_NT_HEADERS *nt_header= (const IMAGE_NT_HEADERS *)((char *)&__ImageBase + __ImageBase.e_lfanew);

И используйте nt_header->FileHeader.TimeDateStamp , чтобы получить timestamp, который находится в секундах от 1/1/1970.


  Сведения об ответе

+-*/

13:35, 28th August, 2020

__TIME__ и __DATE__ могут работать, однако есть некоторые сложности.

Если вы помещаете эти определения в файл .h и включаете определения из нескольких .c/.cpp файлов, каждый файл будет иметь другую версию даты/времени на основе того, когда он будет скомпилирован. Поэтому, если вы хотите использовать дату/время в двух разных местах, и они всегда должны совпадать, вы в беде. Если вы выполняете инкрементную сборку, один из файлов может быть перестроен, а другой-нет, что опять же приводит к появлению временных меток, которые могут сильно отличаться.

Несколько лучший подход заключается в том, чтобы сделать прототипы GetBuildTimeStamp() в файле .h и поместить __TIME__ и __DATE__ macros в реализацию(.c/.cpp) файл. Таким образом, вы можете использовать временные метки в нескольких местах кода, и они всегда будут совпадать. Однако вы должны убедиться, что это так .c/.cpp файл перестраивается каждый раз при выполнении сборки. Если вы делаете чистые сборки, то это решение может работать для вас.

Если вы делаете инкрементные сборки, то вам нужно убедиться, что штамп сборки обновляется на каждой сборке. В Visual C++ вы можете сделать это с помощью PreBuild шагов - однако в этом случае я бы рекомендовал вместо использования __DATE__ и __TIME__ в скомпилированном виде .c/.cpp file, вы используете текстовый файл, который считывается во время выполнения программы. Это делает его быстрым для вашего сценария сборки, чтобы обновить timestamp (не требуется компиляция или связывание) и не требует вашего шага PreBuild, чтобы понять ваши флаги компилятора или параметры.


  Сведения об ответе

lourence

18:55, 16th August, 2020

Я думаю, что предложенные решения для использования DATE, TIME или TIMESTAMP были бы достаточно хороши. Я действительно рекомендую получить доступ к сенсорной программе, чтобы включить ее в шаг предварительной сборки, чтобы коснуться файла, который содержит использование переменной препроцессора. Прикосновение к файлу гарантирует, что его timestamp является более новым, чем в момент его последней компиляции. Таким образом, дата и время в скомпилированном файле также изменяются при каждом перестроении.


  Сведения об ответе

screen

07:16, 3rd August, 2020

Visual C++ также поддерживает __TIMESTAMP__ , что почти точно соответствует вашим требованиям. Тем не менее, самое сложное в метках времени сборки-это поддерживать их в актуальном состоянии, что означает компиляцию файла, в котором __TIMESTAMP__ используется при каждом перестроении. Хотя я не уверен, что есть способ настроить это в Visual C++.


Ответить на вопрос

Чтобы ответить на вопрос вам нужно войти в систему или зарегистрироваться