Memory allocation purity

Steven Schveighoffer via Digitalmars-d digitalmars-d at puremagic.com
Mon May 19 12:20:46 PDT 2014


On Mon, 19 May 2014 15:03:55 -0400, Dicebot <public at dicebot.lv> wrote:

> On Monday, 19 May 2014 at 17:35:34 UTC, Steven Schveighoffer wrote:
>> On Mon, 19 May 2014 13:31:08 -0400, Ola Fosheim Grøstad  
>> <ola.fosheim.grostad+dlang at gmail.com> wrote:
>>
>>> On Monday, 19 May 2014 at 17:11:43 UTC, Steven Schveighoffer wrote:
>>>> It shouldn't matter. Something that returns immutable references, can  
>>>> return that same thing again if asked the same way. Nobody should be  
>>>> looking at the address in any meaningful way.
>>>
>>> I think this is at odds with generic programming. What you are saying  
>>> is that if you plug a pure function into an algorithm then you have to  
>>> test for "pure" in the algorithm if it is affected by object identity.  
>>> Otherwise, goodbye plug-n-play.
>>
>> I think I misstated this, of course, looking at the address for certain  
>> reasons is OK, Object identity being one of them.
>
> immutable(Object*) alloc() pure
> {
>      return new Object();
> }
>
> bool oops() pure
> {
>      auto a = alloc();
>      auto b = alloc();
>      return a is b;
> }
>
> This is a snippet that will always return `true` if memoization is at  
> work and `false` if strongly pure function will get actually called  
> twice. If changing result of your program because of silently enabled  
> compiler optimization does not indicate a broken compiler I don't know  
> what does.

The code is incorrectly implemented, let me fix it:

bool oops() pure
{
   return false;
}

-Steve


More information about the Digitalmars-d mailing list