#include <stdio.h> #include <stdlib.h> #define NLIVE 1000000 #define NITERS (3*1000*1000) char* arr[NLIVE]; int main ( void ) { int i, j, nbytes = 0; printf("initialising\n"); for (i = 0; i < NLIVE; i++) arr[i] = NULL; printf("running\n"); j = -1; for (i = 0; i < NITERS; i++) { j++; if (j == NLIVE) j = 0; if (arr[j]) free(arr[j]); arr[j] = malloc(nbytes); // Cycle through the sizes 0,8,16,24,32. Zero will get rounded up to // 8, so the 8B bucket will get twice as much traffic. nbytes += 8; if (nbytes > 32) nbytes = 0; } for (i = 0; i < NLIVE; i++) if (arr[i]) free(arr[i]); printf("done\n"); return 0; }