Details | Last modification | View Log | RSS feed
Rev | Author | Line No. | Line |
---|---|---|---|
3 | magnus | 1 | <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> |
2 | <html><head> |
||
3 | <title>liboop: oop_malloc(), oop_free()</title> |
||
4 | <link rel="stylesheet" type="text/css" href="style.css"> |
||
5 | </head><body> |
||
6 | |||
7 | <h2>oop_malloc(), oop_free()</h2> |
||
8 | |||
9 | <pre> |
||
10 | #include <oop.h> |
||
11 | |||
12 | extern void *(*oop_malloc)(size_t len); /* <em>Allocate memory.</em> */ |
||
13 | extern void *(*oop_realloc<a href="#note-realloc">*</a>)(void *ptr,size_t len); /* <em>Resize memory.</em> */ |
||
14 | extern void (*oop_free)(void *ptr); /* <em>Free allocated memory.</em> */ |
||
15 | </pre> |
||
16 | |||
17 | <h3>Arguments.</h3> |
||
18 | |||
19 | <dl> |
||
20 | <dt><b>size_t len</b> |
||
21 | <dd>Size, in bytes, of the memory block to allocate.<p> |
||
22 | |||
23 | <dt><b>void *ptr</b> |
||
24 | <dd>Pointer to memory block to free or reallocate.<p> |
||
25 | </dl> |
||
26 | |||
27 | <h3>Description.</h3> |
||
28 | |||
29 | These are global function pointers, initialized by default to the standard C |
||
30 | library functions <em>malloc</em>, <em>realloc</em>, and <em>free</em>. |
||
31 | Applications using liboop may reset these pointers to allocation and |
||
32 | deallocation routines with a compatible interface; libraries should use |
||
33 | these function pointers wherever possible to allocate and release memory. |
||
34 | These pointers are normally set before calling any liboop code; if they |
||
35 | are changed during operation, the new <em>oop_free</em> and |
||
36 | <em>oop_realloc</em> functions should be |
||
37 | capable of handling memory obtained with the old <em>oop_malloc</em>. |
||
38 | |||
39 | <dl> |
||
40 | <dt><b>oop_malloc</b> |
||
41 | <dd>This function allocates a block of memory of size <em>len</em> and returns |
||
42 | a pointer to the start of the block. If allocation fails, NULL is returned.<p> |
||
43 | |||
44 | <dt><b>oop_realloc</b><a href="#note-realloc">*</a> |
||
45 | <dd>This function resizes a block of memory at <em>ptr</em> to have the new |
||
46 | length <em>len</em>. If <em>ptr</em> is NULL, fresh memory is allocated. |
||
47 | If <em>len</em> is zero, memory is freed and NULL is returned. |
||
48 | If <em>ptr</em> is NULL and <em>len</em> is zero, nothing is done and NULL |
||
49 | is returned. If reallocation fails, NULL is returned.<p> |
||
50 | |||
51 | <dt><b>oop_free</b> |
||
52 | <dd>This function releases a block of memory, designated by <em>ptr</em>, |
||
53 | previously allocated by <em>oop_malloc</em>. Once released, the memory may |
||
54 | be immediately overwritten, and/or reused by subsequent calls to |
||
55 | <em>oop_malloc</em>. |
||
56 | </dl> |
||
57 | |||
58 | <hr> |
||
59 | <p><a name="note-realloc">*</a> <b>Compatibility note:</b> oop_realloc |
||
60 | is only available in version 0.7 or newer.</p> |
||
61 | |||
62 | <hr><a href="ref">liboop reference</a></body></html> |