Y
Hacker News
new
|
ask
|
show
|
jobs
by
gus_massa
1027 days ago
Sorry if I got the syntax wrong, but in something like
f = { x = (list 1 2 3) y = (list x x) z = (get x 1) <- y }
How does the compiler decides if it must free the memory used by x?
3 comments
s_Hogg
1027 days ago
All lists are passed by value and X isn't the return value, would be my guess
link
_a_a_a_
1026 days ago
It's an interpreter rather than a compiler, and looking at the code it seems to use ref counting
link
gus_massa
1026 days ago
Ref counting makes a lot of sense with the description of the OP, and if there are no cycles it's good.
link
yeputons
1026 days ago
It should. Everything is copied and by-value, there are no references/pointers or even closures, cycles are impossible. Think Pascal that has garbage collection for strings and dynamic arrays.
link