mirror of
https://codeberg.org/ziglings/exercises.git
synced 2026-06-08 07:50:00 +00:00
improvements for async-io
This commit is contained in:
@@ -6,41 +6,47 @@
|
|||||||
// won't necessarily be available until you call .await() on it:
|
// won't necessarily be available until you call .await() on it:
|
||||||
//
|
//
|
||||||
// var future = io.async(someFunction, .{ arg1, arg2 });
|
// var future = io.async(someFunction, .{ arg1, arg2 });
|
||||||
// // ... do other work here ...
|
|
||||||
// const result = future.await(io);
|
// const result = future.await(io);
|
||||||
//
|
//
|
||||||
// The function *may* run immediately or on another thread -
|
// The function *may* run immediately or on another thread -
|
||||||
// your code doesn't need to care! That's the beauty of the
|
// your code doesn't need to care! That's the beauty of the
|
||||||
// Io abstraction. (In the Threaded backend, if no thread is
|
// Io abstraction.
|
||||||
// available, the function runs synchronously right away and
|
|
||||||
// .await() just returns the already-computed result.)
|
|
||||||
//
|
//
|
||||||
// io.async() returns a Future(T) where T is the return type
|
// IMPORTANT: Every Future MUST be either .await()ed or .cancel()ed.
|
||||||
// of the function you passed in. Future has two key methods:
|
// Failing to do so leaks resources! A safe pattern is:
|
||||||
//
|
//
|
||||||
// .await(io) - block until the result is ready, return it
|
// var future = io.async(myFn, .{});
|
||||||
// .cancel(io) - request cancellation, then return the result
|
// defer _ = future.cancel(io); // safety net
|
||||||
|
// // ... later, if we want the result:
|
||||||
|
// const result = future.await(io);
|
||||||
|
// // (await after cancel is fine — it just returns the result)
|
||||||
|
//
|
||||||
|
// Both .await() and .cancel() block until the task finishes and
|
||||||
|
// return the result. The difference is that .cancel() also
|
||||||
|
// requests the task to stop at its next cancellation point.
|
||||||
|
// Calling either one more than once is safe — subsequent calls
|
||||||
|
// just return a copy of the result.
|
||||||
//
|
//
|
||||||
// Fix this program so that computeAnswer runs asynchronously
|
// Fix this program so that computeAnswer runs asynchronously
|
||||||
// and its result is properly awaited.
|
// and its result is properly awaited.
|
||||||
//
|
//
|
||||||
const std = @import("std");
|
const std = @import("std");
|
||||||
|
const print = std.debug.print;
|
||||||
|
|
||||||
pub fn main(init: std.process.Init) !void {
|
pub fn main(init: std.process.Init) !void {
|
||||||
const io = init.io;
|
const io = init.io;
|
||||||
|
|
||||||
// Launch computeAnswer asynchronously.
|
// Launch computeAnswer asynchronously.
|
||||||
// io.async() takes a function and a tuple of its arguments.
|
|
||||||
var future = io.async(computeAnswer, .{ 6, 7 });
|
var future = io.async(computeAnswer, .{ 6, 7 });
|
||||||
|
defer _ = future.cancel(io); // always clean up!
|
||||||
|
|
||||||
// Meanwhile, print something to show we're not blocked.
|
print("Computing... ", .{});
|
||||||
std.debug.print("Computing... ", .{});
|
|
||||||
|
|
||||||
// Now collect the result. What method on Future gives us
|
// Now collect the result. What method on Future gives us
|
||||||
// the value, blocking if it isn't ready yet?
|
// the value, blocking until it's ready?
|
||||||
const answer = future.???(io);
|
const answer = future.???(io);
|
||||||
|
|
||||||
std.debug.print("The answer is: {}\n", .{answer});
|
print("The answer is: {}\n", .{answer});
|
||||||
}
|
}
|
||||||
|
|
||||||
fn computeAnswer(a: u32, b: u32) u32 {
|
fn computeAnswer(a: u32, b: u32) u32 {
|
||||||
|
|||||||
@@ -1,11 +1,11 @@
|
|||||||
--- exercises/086_async2.zig 2026-04-03 19:42:15.274532915 +0200
|
--- exercises/086_async2.zig 2026-04-05 12:41:11.350626443 +0200
|
||||||
+++ answers/086_async2.zig 2026-04-03 21:30:18.180019206 +0200
|
+++ answers/086_async2.zig 2026-04-05 12:42:00.879791167 +0200
|
||||||
@@ -38,7 +38,7 @@
|
@@ -44,7 +44,7 @@
|
||||||
|
|
||||||
// Now collect the result. What method on Future gives us
|
// Now collect the result. What method on Future gives us
|
||||||
// the value, blocking if it isn't ready yet?
|
// the value, blocking until it's ready?
|
||||||
- const answer = future.???(io);
|
- const answer = future.???(io);
|
||||||
+ const answer = future.await(io);
|
+ const answer = future.await(io);
|
||||||
|
|
||||||
std.debug.print("The answer is: {}\n", .{answer});
|
print("The answer is: {}\n", .{answer});
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user