Skip to content
EMPS intranet

Back to top
Hi!   Hi!           Start main()

Try stepping through the code


  Value and type of last evaluated expression: Address of array element: Address of array elementx:  (none)

Your browser does not support the canvas element which will make some the features unavailable.

If you are using Internet Explorer within the University of Exeter try going to the Settings menu (probably the gear shape at the top right of this page), selecting "Compatibility View settings", unchecking "Display intranet sites in Compatibility View" and reloading this page.

Code

 Header...
#define NDIM 2 typedef struct particle { float x[NDIM]; float mass; struct particle *next; }Particle; // Allocate a new particle and add it to the start of the list
struct particle* newparticle(Particle *first){
  ...
» Particle *p; » p=xmalloc(sizeof *p); » p->next=first; // Now initialise exactly as before » printf("Please enter the mass and x and y values.\n"); » scanf("%f %f %f", &p->mass, &p->x[0], &p->x[1]); » return p;
} // !! This function demonstrates a memory leak /* * Free Particle "togo" and return the new first Particle * "first" must be the existing first member of the list */ struct particle* freeparticle(Particle *togo,Particle *first){
  ...
» Particle *parent; » if (togo==NULL) // Do nothing return first; else if (first==NULL) { » fprintf(stderr, "Trying to remove something from an empty list!\n"); » return NULL; } » if (togo==first) // Is it the first one? first=first->next; else {// Find togo's predecessor: » for (parent=first; parent->next!=togo; parent=parent->next) { » if (parent->next==NULL) { » fprintf(stderr, "%p isn't in the list!\n", togo); » return first; } } » parent->next=togo->next; } // free(togo); » return first;
} int main(){
  ...
» int i, n; » Particle *first=NULL; » printf("How many structures would you like?\n"); » scanf("%d", &n); » for (i=0; i<n; ++i) first=newparticle(first); // Demonstrate some cases of freeing a particle » Particle *killme=first->next->next; » first=freeparticle(killme, first); » killme=first; » first=freeparticle(killme, first); » killme=NULL; » first=freeparticle(killme, first); » for ( Particle *p=first;p!=NULL; p=p->next) printf("Mass: %f position: (%g, %g)\n", p->mass, p->x[0], p->x[1]); » return 0;
}
Memory

Allocated memory

128
129
130
131
132
133
134
135
128.x[0] = -3.37056e-09
128.x[1] = -65.6378
136
137
138
139
140
141
142
143
128.mass = 442.926147
128.next = -153780058

152
153
154
155
156
157
158
159
152.x[0] = 7.58196e-05
152.x[1] = -3.972e+22
160
161
162
163
164
165
166
167
152.mass = -7.24028635
152.next = -142172391

176
177
178
179
180
181
182
183
176.x[0] = 9.99048e+10
176.x[1] = -6.49875e-28
184
185
186
187
188
189
190
191
176.mass = 2394314.25
176.next = -154187561

200
201
202
203
204
205
206
207
200.x[0] = 2.08246e-27
200.x[1] = -1.4272e-30
208
209
210
211
212
213
214
215
200.mass = 2.41032934e+20
200.next = -150219387

freeparticle()

344
345
346
347
348
349
350
351
first = -4129238304
togo = -4129238352
360
361
362
363
parent = -4287582286

freeparticle()

344
345
346
347
348
349
350
351
first = -4129238328
togo = NULL
360
361
362
363
parent = -4287582286

freeparticle()

344
345
346
347
348
349
350
351
first = -4129238304
togo = -4129238304
360
361
362
363
parent = -4287582286

newparticle()

348
349
350
351
first = NULL
360
361
362
363
p = -4287582286

newparticle()

348
349
350
351
first = -4129238352
360
361
362
363
p = -4287582286

newparticle()

348
349
350
351
first = -4129238376
360
361
362
363
p = -4287582286

newparticle()

348
349
350
351
first = -4129238328
360
361
362
363
p = -4287582286

main()

456
457
458
459
460
461
462
463
i = 1
n = 200
464
465
466
467
468
469
470
471
first = NULL
killme = -4129238352

main(): for()

472
473
474
475
p = -4129238328

NB: the actual memory address of each variable is the
address shown plus 4287582288 (0xFF8F5050).

The actual address of allocated memory is the
address shown plus 158343784 (0x9702268).

Show Advanced options

.

Input was:

4 
4.1 2.4 7.7 
5.0 6.3 8.6 
3.6 4.3 2.91 
7.2 5.7 6.1

Show output (Before looking at the output, work out what you think it put should be and see if you are right.)

Output

How many structures would you like?
Please enter the mass and x and y values.
Please enter the mass and x and y values.
Please enter the mass and x and y values.
Please enter the mass and x and y values.
Mass: 3.600000 position: (4.3, 2.91)
Mass: 4.100000 position: (2.4, 7.7)
                                                                                                                                                                                                                                                                       

Validate   Link-check © Copyright & disclaimer Share
Back to top