jin-go ~imgbot
Thread-pooled coroutines with lock-free staticaly typed communication channels
To use this package, run the following command in your project's root directory:
Manual usage
Put the following dependency into your project's dependences section:
Go.d
Thread-pooled coroutines with wait-free staticaly typed communication channels
Features
- Static typed channels (but you can use Algebraic to transfer various data).
- Minimal message size (no additional memory cost).
- Wait free channels (but if you don't check for avalability you wil be spinlocked).
- Static check for message transition safety (allowed only shared, immutable and non-copiable).
- Every goroutine runs on thread poll.
ToDo
- Fibers support (Should be used Fiber.yield instead of spinlock).
- Main thread usage (It is spinlocking now).
Benchmarks
> .\compare.cmd
>go run app.go --release
Workers Result Time
4 499500000 27.9226ms
>dub --quiet --build=release
Workers Result Time
3 499500000 64 ms
Usage
dub.json:
{
"dependencies": {
"jin-go": "~>1.0.0"
}
}
Import
import jin.go;
Create channels
auto ints = new Channel!int;
struct Data { int val }
struct End {}
alias Algebraic!(Data,End) Message
Input!Message messages_input;
auto messages_output = messages_input.pair;
auto messages_input2 = messages_output.pair;
Inputs!int ints_in;
Outputs!int ints_out;
Start coroutines
void incrementing( Output!int ints_out , Input!int ints_in ) {
while( ints_out.available >= 0 ) {
ints_out.next = ints_in.next + 1;
}
}
go!incrementing( ints_in.pair , ints_out.pair );
auto ints_in = go!incrementing( ints_out.pair ); // ditto
auto squaring( int limit ) {
return limit.iota.map( i => i^^2 );
}
auto squares_in = go!squaring( 10 );
Send messages
waits while outbox/outboxes is full
ints.next = 123; // send message
ints.next!Data = 123; // make and send message
ints.put( 123 ); // OutputRange style
Receive messages
waits for any message in inbox/inboxes
writeln( results.next ); // get one message
writeln( results.next.get!Data ); // get value from one Message
// visit one Message
results.next.visit!(
( Data data ) { writeln( data ); } ,
( End end ) { } ,
);
// handle messages in cycle
while( !results.empty ) {
if( results.pending > 0 ) writeln( results.next );
};
// handle messages from multiple channels in cycle
while( !one.empty || !two.empty ) {
if( one.pending > 0 ) writeln( one.next );
if( two.pending > 0 ) writeln( two.next );
}
Complete example
currently broken
import core.time;
import std.stdio;
import jin.go;
static auto after( Channel!bool channel , Duration dur )
{
sleep( dur );
if( !channel.closed ) channel.next = true;
}
static auto tick( Channel!bool channel , Duration dur )
{
while( !channel.closed ) after( channel , dur );
}
void main(){
auto ticks = go!tick( 101.msecs );
auto booms = go!after( 501.msecs );
string log;
while( booms.clear )
{
while( !ticks.clear ) {
writeln( "tick" );
ticks.popFront;
}
writeln( "." );
sleep( 51.msecs );
}
writeln( "BOOM!" );
}
- Registered by nin jin
- ~imgbot released 5 years ago
- nin-jin/go.d
- public domain
- public domain © 2015, jin
- Authors:
- Dependencies:
- dests
- Versions:
-
3.0.0 2024-Dec-27 2.0.1 2020-Jun-17 2.0.0 2020-Jun-14 1.0.5 2016-Mar-29 1.0.4 2016-Mar-29 - Download Stats:
-
-
0 downloads today
-
0 downloads this week
-
1 downloads this month
-
159 downloads total
-
- Score:
- 2.0
- Short URL:
- jin-go.dub.pm