Still A Memory Leak?
There is more than one way to define 'memory leak'. In particular, there are two primary definitions of 'memory leak' that are in common usage among programmers.
The first commonly used definition of 'memory leak' is, 'Memory was allocated and was not subsequently freed before the program terminated.' However, many programmers (rightly) argue that certain types of memory leaks that fit this definition don't actually pose any sort of problem, and therefore should not be considered true 'memory leaks'. An arguably stricter (and more useful) definition of 'memory leak' is, 'Memory was allocated and cannot be subsequently freed because the program no longer has any pointers to the allocated memory block.'
In other words, you cannot free memory that you no longer have any pointers to. Such memory is therefore a 'memory leak'. Valgrind uses this stricter definition of the term 'memory leak'. This is the type of leak which can potentially cause significant heap depletion, especially for long lived processes. The 'still reachable' category within Valgrind's leak report refers to allocations that fit only the first definition of 'memory leak'. These blocks were not freed, but they could have been freed (if the programmer had wanted to) because the program still was keeping track of pointers to those memory blocks.
In general, there is no need to worry about 'still reachable' blocks. They don't pose the sort of problem that true memory leaks can cause.
For instance, there is normally no potential for heap exhaustion from 'still reachable' blocks. This is because these blocks are usually one-time allocations, references to which are kept throughout the duration of the process's lifetime. While you could go through and ensure that your program frees all allocated memory, there is usually no practical benefit from doing so since the operating system will reclaim all of the process's memory after the process terminates, anyway. Contrast this with true memory leaks which, if left unfixed, could cause a process to run out of memory if left running long enough, or will simply cause a process to consume far more memory than is necessary. Probably the only time it is useful to ensure that all allocations have matching 'frees' is if your leak detection tools cannot tell which blocks are 'still reachable' (but Valgrind can do this) or if your operating system doesn't reclaim all of a terminating process's memory (all platforms which Valgrind has been ported to do this). 'many programmers (rightly) argue that leaked memory don't actually pose a problem, and therefore should not be considered true memory leaks' - Lol. Build a native DLL with that sort of memory leak, and then have Java or.Net consume it.
Java and.Net load and unload DLLs thousands of times during life of a program. Each time the DLL is reloaded it will leak a little more memory. Long running programs will eventually run out of memory.
It drives Debian's OpenJDK maintainer mad. He said the same on the OpenSSL mailing list while we were discussing OpenSSL's 'benign' memory leaks. – Aug 23 at 16:20. Since there is some routine from the the pthread family on the bottom (but I don't know that particular one), my guess would be that you have launched some thread as joinable that has terminated execution. The exit state information of that thread is kept available until you call pthreadjoin. Thus, the memory is kept in a loss record at program termination, but it is still reachable since you could use pthreadjoin to access it. If this analysis is correct, either launch these threads detached, or join them before terminating your program.
Edit: I ran your sample program (after some obvious corrections) and I don't have errors but the following 18933 ERROR SUMMARY: 0 errors from 0 contexts (suppressed: 4 from 4) -18933- -18933- usedsuppression: 2 dl-hack3-cond-1 -18933- usedsuppression: 2 glibc-2.5.x-on-SUSE-10.2-(PPC)-2a Since the dl- thing resembles much of what you see I guess that you see a known problem that has a solution in terms of a suppression file for valgrind. Perhaps your system is not up to date, or your distribution doesn't maintain these things.
Still A Memory Leak Windows 10
(Mine is ubuntu 10.4, 64bit).