On May 28, 2009, at 2:29 AM, Ian Hickson wrote:


I just checked in a substantial change to the lifetime model for workers.
Instead of being bound to their ports, which became especially hard to
implement for shared workers, they now just live as long as the Document
that created them (all of the Documents that obtained them, for shared
workers), with this ownership inheriting to nested workers.

I also removed the various ways to observe the lifetime, namely .active
and the 'close' events.

I hope this will make the shared workers easier to implement. Please let
me know if this screws anything up for dedicated workers.

I'm assuming this is one of the changes:

User agents must either act as if MessagePort objects have a strong reference to their entangled MessagePort object or as if each MessagePort object's owner has a strong reference to the MessagePort object.

It seems to me the second alternative prevents MessagePorts created by a Window from ever being garbage collected until the user leaves the page. Is that a correct understanding? If so, that seems like it could create unbounded memory leaks in long-running Web applications that use MessagePorts, even if all references to both endpoints of the MessageChannel are dropped. That seems unacceptable to me, unless I misunderstood.

Regards,
Maciej

Reply via email to