Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Use-case of `oneway void` in Objective-C?

I found a strange keyword in NSObject.h

- (oneway void)release;

I searched the web, and learned it relates to asynchronous message passing, which looks similar with Erlang's message passing.

It seems this can make many interesting things. What are some good use-cases of this keyword?

like image 659
eonil Avatar asked Mar 31 '11 03:03

eonil


2 Answers

oneway is used with the distributed objects API, which allows use of objective-c objects between different threads or applications. It tells the system that it should not block the calling thread until the method returns. Without it, the caller will block, even though the method's return type is void. Obviously, it is never used with anything other than void, as doing so would mean the method returns something, but the caller doesn't get it.

For more on distributed objects, see Cocoa Conceptual DistrObjects.

like image 173
ughoavgfhw Avatar answered Nov 18 '22 01:11

ughoavgfhw


According to Apple's documentation oneway is only used for distributed object (and not for multithreading).

The oneway modifier is only used if the object is remote. In this case the release call can return asynchronously (before the method has terminated). In a network it makes sense because waiting for a return message can take a while.

The release method has no return value and so call it can be executed asynchronously. In contrast, retain and autorelease return an id and so we have to wait for the return message to be transferred throughout the network.

like image 45
Freeman Avatar answered Nov 18 '22 01:11

Freeman