C / POSIX
Ten program wykorzystuje liczbę twardych dowiązań do własnego pliku wykonywalnego jako licznik tego, jak często był wywoływany. Tworzy nowe twarde dowiązania w katalogu, z którego został uruchomiony (ponieważ w ten sposób gwarantuje to, że znajduje się w tym samym systemie plików), co wymaga uprawnień do zapisu. Pominąłem obsługę błędów.
Lepiej upewnij się, że nie masz ważnego pliku o takiej samej nazwie jak jeden z utworzonych twardych linków w tym katalogu, w przeciwnym razie zostanie on nadpisany. Jeśli na przykład plik wykonywalny nazywa counter, twarde linki zostaną nazwane counter_1, counter_2etc.
#include <sys/types.h>
#include <sys/stat.h>
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main(int argc, char* argv[])
{
/* get persistent counter */
struct stat selfstat;
stat(argv[0], &selfstat);
int counter = selfstat.st_nlink;
/* determine digits of counter */
int countercopy = counter;
int digits = 1;
while (countercopy /= 10)
++digits;
/* increment persistent counter */
char* newname = malloc(strlen(argv[0]) + digits + 2);
sprintf(newname, "%s_%d", argv[0], counter);
link(argv[0], newname);
/* output the counter */
if (counter & (counter-1)) // this is zero iff counter is a power of two
printf("%d\n", counter);
else
{
/* determine which power of 2 it is */
int power = 0;
while (counter/=2)
++power;
printf("2^%d\n", power);
}
return 0;
}
Przykład uruchomienia (pierwszy wiersz resetuje licznik, jeśli plik wykonywalny został już uruchomiony):
$ rm counter_*
$ ./counter
2^0
$ ./counter
2^1
$ ./counter
3
$ ./counter
2^2
$ ./counter
5
$ ./counter
6
$ ./counter
7
$ ./counter
2^3
$ ./counter
9
$ ls counter*
counter counter_2 counter_4 counter_6 counter_8 counter.c
counter_1 counter_3 counter_5 counter_7 counter_9 counter.c~
0w pierwszym uruchomieniu?