data:image/s3,"s3://crabby-images/ccdc1/ccdc1049aba01e92be7e1c753d4607efb80720a4" alt="Kotlin weak reference"
data:image/s3,"s3://crabby-images/143cb/143cb1e4edd203c5b114456857c98c0af1890451" alt="kotlin weak reference kotlin weak reference"
The very concept of garbage collection as a form of automated management was invented by John McCarthy for LISP in 1959.
data:image/s3,"s3://crabby-images/9fd22/9fd224095dd3642e1e415671ab7aadf5681e5a7f" alt="kotlin weak reference kotlin weak reference"
That was all done automatically by a garbage collector. In LISP you could work with dynamically-sized data structures without having to declare limits on their sizes upfront and without having to write code to allocate and free up the underlying memory.
data:image/s3,"s3://crabby-images/43eae/43eaeda2ade8f5fdbe9975d818d323ff309ce037" alt="kotlin weak reference kotlin weak reference"
This left it up to developers to write explicit code that allocates and frees memory in the heap. PL/I in 1966 and Algol-68 were the first two major languages that added the concept of dynamically allocated memory as we know it today, establishing the tradition of manual memory management. This made things easy and simple, but it limited software to working with data of fixed sizes, and limits on the number of processed items had to be hard-coded in the source code. Developers did not have to think about memory allocation and deallocation at run time, as memory was either always allocated (statically) or automatically managed (via the stack) and nothing had to be done “manually”. All the memory was either statically or stack allocated. Early programming languages did not have the concept of a heap at all. The very concept of automatic memory management is as old as programming languages.
data:image/s3,"s3://crabby-images/2354d/2354da71c2f63b293ed371bf41c499fa7c44dd5e" alt="kotlin weak reference kotlin weak reference"
data:image/s3,"s3://crabby-images/ccdc1/ccdc1049aba01e92be7e1c753d4607efb80720a4" alt="Kotlin weak reference"