#include #include #include struct list { struct list *next; }; int main(void) { int z=999; int *y=&z; int *x=NULL; struct list *save; struct list *lp; int i; printf("pointer to x is %p\n", x); printf("pointer to y is %p\n", y); x=malloc(sizeof(int)*2000); printf("pointer to x is %p\n", x); y=malloc(sizeof(int)*100); printf("pointer to y is %p\n", y); free(x); free(y); printf("about to free(0)\n"); free(0); x=malloc(13); printf("x = %p\n", x); memcpy(x, "Small string", 13); printf("0x%p test string1: %s\n", x, (char *)x); y = realloc(x, 36); printf("0x%p test string1: %s\n", y, (char *)y); memcpy(y, "********** Larger string **********", 36); printf("0x%p test string2: %s\n", y, (char *)y); free(y); printf("Allocate 100 nodes 500 bytes each\n"); save = 0; for (i=0; i<100; i++) { lp = malloc(500); if (lp == 0) { printf("loop 1: malloc returned 0\n"); goto Failed; } lp->next = save; save = lp; } printf("freeing 100 nodes\n"); while (save) { lp = save; save = save->next; free(lp); } printf("try realloc 100 times \n"); lp = 0; for (i=1; i<=100; i++) { lp = realloc(lp, i*200); if (lp == 0) { printf("loop 3: realloc returned 0\n"); goto Failed; } } { void *unused_ret = realloc(lp, 0); (void) unused_ret; } printf("Allocate another 100 nodes 600 bytes each\n"); save = 0; for (i=0; i<100; i++) { lp = malloc(600); if (lp == 0) { printf("loop 2: malloc returned 0\n"); goto Failed; } lp->next = save; save = lp; } printf("freeing 100 nodes\n"); while (save) { lp = save; save = save->next; free(lp); } printf("alloc test PASSED\n"); exit(0); Failed: printf("!!!!!!!!!!!! alloc test FAILED. !!!!!!!!!!!!!!!\n"); exit(1); }