forcing weak purity
deadalnix
deadalnix at gmail.com
Wed May 23 07:03:01 PDT 2012
Le 23/05/2012 15:57, Steven Schveighoffer a écrit :
> On Wed, 23 May 2012 09:52:31 -0400, deadalnix <deadalnix at gmail.com> wrote:
>
>> Le 23/05/2012 14:35, Steven Schveighoffer a écrit :
>>> Yes. Memory allocation and deallocation from a global heap is by
>>> definition an impure operation (it affects global state). However, we
>>> must make exceptions because without being able to allocate memory, pure
>>> functions become quite trivial and useless.
>>>
>>> In functional languages, if such exceptions were not granted, a program
>>> would not be able to do much of anything.
>>>
>>
>> Yes, you are missing the point.
>>
>> collect is not something you should be able to call in a pure
>> function. It can be triggered by allocating, but at this point you
>> already are in an impure context called from a pure context.
>>
>> At the end, you need an unsafe way to call impure code in pure functions.
>
> I'm failing to see an argument in this response. If I can call an impure
> function for allocating memory, why is it illegal to call an impure
> function for collecting unused memory?
>
> -Steve
Allocating is a much more simpler operation than collect, and its impact
is way more reduced.
Plus, allocating memory is something mandatory to do anything non
trivial. GC collect isn't that important, as it can be triggered by
allocating mecanism itself (and this mecanism is already impure).
If you do allow everything impure to be done on pure function based on
the fact that allocating is impure, what is the point to have pure
function at all ?
More information about the Digitalmars-d
mailing list