Hi all,
Futures (aka Promises) are a well known concept that aid in writing asynchronous code. I’d love to have a Future type that comes with the language.
The way I’d see this work is similar to how Optionals are currently implemented. There’d be a Future<T> type in the standard library, but most developers will choose not to use it directly. Instead, there are some new keywords and syntactic sugar that make it easy to work with the Future concept.
There’d be a new ‘async’ keyword indicating that a type (including return type) is asynchronous:
func blurImage(image: UIImage, radius: Int) -> async UIImage {
var blurredImage: async UIImage
dispatch_async(globalQueue) {
blurredImage = // expensive blur operation
}
return blurredImage
}
At the origin of an asynchronous value is something like GCD to actually execute the work on a different thread. (This is not the responsibility of the Future.)
An async type should largely just work like its ‘regular’ synchronous counterpart. The compiler would be able to generate code for methods on that type (e.g. hasPrefix(_:) on an async string returns an async Bool) or methods (including operators) that take that type as a parameter (E.g. concatenating two async strings should be as easy as: string1 + string2).
To unwrap a Future, i.e. getting its value, for cases that do not accept asynchronous values (e.g. UI updates), there’d be a new ‘when let’ statement with a control flow that is similar to the guard statement:
when let image = blurImage(image) else {
throw ImageBlurringFailed()
}
imageView.image = image
This is all very brief, but should give you an idea of my proposal. You can find more details in a blog post I wrote recently: http://www.thomasvisser.me/2015/11/26/async-swift/\. This description is probably rather simplistic compared to the work needed to actually support something like this, but I hope it can serve as a starting point.
Context:
- There is a proposal by Nadav Rotem from September 2015 that describes a lot of the foundational work that would have to be done before we can have a safe Future type: https://github.com/apple/swift/blob/5eaa3c43d069d5bd401e7879b43f6290823d180d/docs/proposals/Concurrency.rst\. While I think a Future type could exist without language support for concurrency (e.g. using GCD directly, see GitHub - Thomvis/BrightFutures: Write great asynchronous code in Swift using futures and promises, full disclosure: I wrote that library), I agree it makes a lot of sense to only do it once it can be done in a safe way.
- There are other concepts that have to do with asynchronous programming such as channels/signals/observables (Rx) and goroutines. I think there’s a place & audience for more than one of these concepts in Swift, but these efforts should of course be coordinated.
I realize this is not in scope for Swift 3, but I’d love to get feedback from the community and hear how it can be incorporated in the discussion when concurrency will be on the agenda (for Swift 4 perhaps)?
Best,
Thomas Visser