Skip to content

robfors/concurrent_queue

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

3 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ConcurrentQueue

This is a Ruby gem that can be used to listen to multiple queues concurrently and return the value of the first queue to have an item pushed to it.

Install

gem install concurrent_queue

Documentation

You can use ConcurrentQueue instances as you would the core Queue instances. However, only the methods pop, push and length have been implemented. If you want to use this gem and you need more of the core methods feel free to submit a pull request or simply open an issue.

The ConcurrentQueue class also offers a new method pop. Call this with a ConcurrentQueue instance or Array of ConcurrentQueue instances and it will listen to all the queues simultaneously. It will immediately return a pre existing item found in any of the queues if found, otherwise it will reutrn the first item pushed to any of the queues. Just like regular queues, the order of items in each individual queue is preserved, however, if a pre existing item is found it will be popped from the earliest queue in the array you provide.

Example

require 'concurrent_queue'

q1 = ConcurrentQueue.new
q2 = ConcurrentQueue.new

t1 = Thread.new do
  puts ConcurrentQueue.pop([q1,q2])
  sleep 2
  puts ConcurrentQueue.pop([q1,q2])
end

t2 = Thread.new do
  sleep 1
  puts ConcurrentQueue.pop([q1,q2])
  sleep 2
  puts ConcurrentQueue.pop([q1,q2])
end

sleep 0.5
q1.push(1)
q1.push(2)
q2.push(3)
q2.push(4)
t1.join
t2.join

About

Listen to multiple queues concurrently and return the value of the first queue to have an item pushed to it.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages