diff options
-rw-r--r-- | MANIFEST | 12 | ||||
-rw-r--r-- | ext/Thread/Queue.pmx | 104 | ||||
-rw-r--r-- | ext/Thread/Semaphore.pmx (renamed from ext/threads/shared/semaphore.pm) | 44 | ||||
-rwxr-xr-x | ext/threads/shared/Makefile.PL | 2 | ||||
-rw-r--r-- | ext/threads/shared/queue.pm | 102 | ||||
-rw-r--r-- | ext/threads/shared/shared.pm | 2 | ||||
-rwxr-xr-x | installperl | 8 | ||||
-rw-r--r-- | lib/Thread/Queue.pm | 90 | ||||
-rw-r--r-- | lib/Thread/Queue.t (renamed from ext/threads/shared/t/queue.t) | 6 | ||||
-rw-r--r-- | lib/Thread/Semaphore.pm | 62 | ||||
-rw-r--r-- | lib/Thread/Semaphore.t (renamed from ext/threads/shared/t/semaphore.t) | 4 | ||||
-rw-r--r-- | pod/perlmodlib.pod | 4 | ||||
-rw-r--r-- | pod/perlthrtut.pod | 20 | ||||
-rw-r--r-- | pod/perltoc.pod | 88 |
14 files changed, 218 insertions, 330 deletions
@@ -651,9 +651,11 @@ ext/Thread/list.tx Test getting list of all threads ext/Thread/lock.tx Test lock primitive ext/Thread/Makefile.PL Thread extension makefile writer ext/Thread/Notes Thread notes +ext/Thread/Queue.pmx Threadsafe queue ext/Thread/queue.tx Test Thread::Queue module ext/Thread/README Thread README ext/Thread/README.threads Notes about multithreading +ext/Thread/Semaphore.pmx Threadsafe semaphore ext/Thread/specific.tx Test thread-specific user data ext/Thread/sync.tx Test thread synchronisation ext/Thread/sync2.tx Test thread synchronisation @@ -670,9 +672,7 @@ ext/threads/Changes ithreads ext/threads/Makefile.PL ithreads ext/threads/README ithreads ext/threads/shared/Makefile.PL thread shared variables -ext/threads/shared/queue.pm Threadsafe queue. ext/threads/shared/README thread shared variables -ext/threads/shared/semaphore.pm Threadsafe semaphore ext/threads/shared/shared.pm thread shared variables ext/threads/shared/shared.xs thread shared variables ext/threads/shared/t/0nothread.t Tests for basic shared array functionality. @@ -682,8 +682,6 @@ ext/threads/shared/t/cond.t Test condition variables ext/threads/shared/t/hv_refs.t Test shared hashes containing references ext/threads/shared/t/hv_simple.t Tests for basic shared hash functionality. ext/threads/shared/t/no_share.t Tests for disabled share on variables. -ext/threads/shared/t/queue.t thread shared variables -ext/threads/shared/t/semaphore.t test semaphore ext/threads/shared/t/shared_attr.t Test :shared attribute ext/threads/shared/t/sv_refs.t thread shared variables ext/threads/shared/t/sv_simple.t thread shared variables @@ -1528,8 +1526,10 @@ lib/Text/TabsWrap/t/tabs.t See if Text::Tabs works lib/Text/TabsWrap/t/wrap.t See if Text::Wrap::wrap works lib/Text/Wrap.pm Paragraph formatter lib/Thread.pm Thread extensions frontend -lib/Thread/Queue.pm Thread synchronised queue objects -lib/Thread/Semaphore.pm Thread semaphore objects +lib/Thread/Queue.pm Threadsafe queue +lib/Thread/Queue.t See if threadsafe queue works +lib/Thread/Semaphore.pm Threadsafe semaphore +lib/Thread/Semaphore.t See if threadsafe semaphore works lib/Tie/Array.pm Base class for tied arrays lib/Tie/Array/push.t Test for Tie::Array lib/Tie/Array/splice.t Test for Tie::Array::SPLICE diff --git a/ext/Thread/Queue.pmx b/ext/Thread/Queue.pmx new file mode 100644 index 0000000000..481261043f --- /dev/null +++ b/ext/Thread/Queue.pmx @@ -0,0 +1,104 @@ +package Thread::Queue; +use Thread qw(cond_wait cond_broadcast); + +=head1 NAME + +Thread::Queue - thread-safe queues (5.005-threads) + +=head1 CAVEAT + +This Perl installation is using the old unsupported "5.005 threads". +Use of the old threads model is discouraged. + +For the whole story about the development of threads in Perl, and why +you should B<not> be using "old threads" unless you know what you're +doing, see the CAVEAT of the C<Thread> module. + +=head1 SYNOPSIS + + use Thread::Queue; + my $q = new Thread::Queue; + $q->enqueue("foo", "bar"); + my $foo = $q->dequeue; # The "bar" is still in the queue. + my $foo = $q->dequeue_nb; # returns "bar", or undef if the queue was + # empty + my $left = $q->pending; # returns the number of items still in the queue + +=head1 DESCRIPTION + +A queue, as implemented by C<Thread::Queue> is a thread-safe data structure +much like a list. Any number of threads can safely add elements to the end +of the list, or remove elements from the head of the list. (Queues don't +permit adding or removing elements from the middle of the list) + +=head1 FUNCTIONS AND METHODS + +=over 8 + +=item new + +The C<new> function creates a new empty queue. + +=item enqueue LIST + +The C<enqueue> method adds a list of scalars on to the end of the queue. +The queue will grow as needed to accomodate the list. + +=item dequeue + +The C<dequeue> method removes a scalar from the head of the queue and +returns it. If the queue is currently empty, C<dequeue> will block the +thread until another thread C<enqueue>s a scalar. + +=item dequeue_nb + +The C<dequeue_nb> method, like the C<dequeue> method, removes a scalar from +the head of the queue and returns it. Unlike C<dequeue>, though, +C<dequeue_nb> won't block if the queue is empty, instead returning +C<undef>. + +=item pending + +The C<pending> method returns the number of items still in the queue. (If +there can be multiple readers on the queue it's best to lock the queue +before checking to make sure that it stays in a consistent state) + +=back + +=head1 SEE ALSO + +L<Thread> + +=cut + +sub new { + my $class = shift; + return bless [@_], $class; +} + +sub dequeue : locked : method { + my $q = shift; + cond_wait $q until @$q; + return shift @$q; +} + +sub dequeue_nb : locked : method { + my $q = shift; + if (@$q) { + return shift @$q; + } else { + return undef; + } +} + +sub enqueue : locked : method { + my $q = shift; + push(@$q, @_) and cond_broadcast $q; +} + +sub pending : locked : method { + my $q = shift; + return scalar(@$q); +} + +1; diff --git a/ext/threads/shared/semaphore.pm b/ext/Thread/Semaphore.pmx index bb114dc5a6..8d69ac540a 100644 --- a/ext/threads/shared/semaphore.pm +++ b/ext/Thread/Semaphore.pmx @@ -1,23 +1,29 @@ -package threads::shared::semaphore; +package Thread::Semaphore; +use Thread qw(cond_wait cond_broadcast); -use threads::shared; +=head1 NAME -our $VERSION = '1.00'; +Thread::Semaphore - thread-safe semaphores (5.005-threads) -=head1 NAME +=head1 CAVEAT + +This Perl installation is using the old unsupported "5.005 threads". +Use of the old threads model is discouraged. -threads::shared::semaphore - thread-safe semaphores +For the whole story about the development of threads in Perl, and why +you should B<not> be using "old threads" unless you know what you're +doing, see the CAVEAT of the C<Thread> module. =head1 SYNOPSIS - use threads::shared::semaphore; - my $s = new threads::shared::semaphore; + use Thread::Semaphore; + my $s = new Thread::Semaphore; $s->up; # Also known as the semaphore V -operation. # The guarded section is here $s->down; # Also known as the semaphore P -operation. # The default semaphore value is 1. - my $s = new threads::shared::semaphore($initial_value); + my $s = new Thread::Semaphore($initial_value); $s->up($up_value); $s->down($up_value); @@ -28,8 +34,8 @@ unlike locks, aren't tied to particular scalars, and so may be used to control access to anything you care to use them for. Semaphores don't limit their values to zero or one, so they can be used to -control access to some resource that there may be more than one of. (For -example, filehandles). Increment and decrement amounts aren't fixed at one +control access to some resource that may have more than one of. (For +example, filehandles) Increment and decrement amounts aren't fixed at one either, so threads can reserve or return multiple resources at once. =head1 FUNCTIONS AND METHODS @@ -48,7 +54,7 @@ number. If no number is passed, the semaphore's count is set to one. =item down NUMBER The C<down> method decreases the semaphore's count by the specified number, -or by one if no number has been specified. If the semaphore's count would drop +or one if no number has been specified. If the semaphore's count would drop below zero, this method will block until such time that the semaphore's count is equal to or larger than the amount you're C<down>ing the semaphore's count by. @@ -58,9 +64,9 @@ semaphore's count by. =item up NUMBER The C<up> method increases the semaphore's count by the number specified, -or by one if no number has been specified. This will unblock any thread blocked +or one if no number's been specified. This will unblock any thread blocked trying to C<down> the semaphore if the C<up> raises the semaphore count -above the amount that the C<down>s are trying to decrement it by. +above what the C<down>s are trying to decrement it by. =back @@ -68,23 +74,21 @@ above the amount that the C<down>s are trying to decrement it by. sub new { my $class = shift; - my $val : shared = @_ ? shift : 1; + my $val = @_ ? shift : 1; bless \$val, $class; } -sub down { +sub down : locked : method { my $s = shift; - lock($$s); my $inc = @_ ? shift : 1; - cond_wait $$s until $$s >= $inc; + cond_wait $s until $$s >= $inc; $$s -= $inc; } -sub up { +sub up : locked : method { my $s = shift; - lock($$s); my $inc = @_ ? shift : 1; - ($$s += $inc) > 0 and cond_broadcast $$s; + ($$s += $inc) > 0 and cond_broadcast $s; } 1; diff --git a/ext/threads/shared/Makefile.PL b/ext/threads/shared/Makefile.PL index aa9faa6b52..18ac115a84 100755 --- a/ext/threads/shared/Makefile.PL +++ b/ext/threads/shared/Makefile.PL @@ -7,8 +7,6 @@ WriteMakefile( 'VERSION_FROM' => 'shared.pm', # finds $VERSION 'PM' => { 'shared.pm' => '$(INST_LIBDIR)/shared.pm', - 'queue.pm' => '$(INST_LIBDIR)/shared/queue.pm', - 'semaphore.pm' => '$(INST_LIBDIR)/shared/semaphore.pm', }, 'PREREQ_PM' => {}, # e.g., Module::Name => 1.1 ($] >= 5.005 ? ## Add these new keywords supported since 5.005 diff --git a/ext/threads/shared/queue.pm b/ext/threads/shared/queue.pm deleted file mode 100644 index 30b6ea29ec..0000000000 --- a/ext/threads/shared/queue.pm +++ /dev/null @@ -1,102 +0,0 @@ -package threads::shared::queue; - -use threads::shared; -use strict; - -our $VERSION = '1.00'; - -=head1 NAME - -threads::shared::queue - thread-safe queues - -=head1 SYNOPSIS - - use threads::shared::queue; - my $q = new threads::shared::queue; - $q->enqueue("foo", "bar"); - my $foo = $q->dequeue; # The "bar" is still in the queue. - my $foo = $q->dequeue_nb; # returns "bar", or undef if the queue was - # empty - my $left = $q->pending; # returns the number of items still in the queue - -=head1 DESCRIPTION - -A queue, as implemented by C<threads::shared::queue> is a thread-safe -data structure much like a list. Any number of threads can safely -add elements to the end of the list, or remove elements from the head -of the list. (Queues don't permit adding or removing elements from -the middle of the list). - -=head1 FUNCTIONS AND METHODS - -=over 8 - -=item new - -The C<new> function creates a new empty queue. - -=item enqueue LIST - -The C<enqueue> method adds a list of scalars on to the end of the queue. -The queue will grow as needed to accommodate the list. - -=item dequeue - -The C<dequeue> method removes a scalar from the head of the queue and -returns it. If the queue is currently empty, C<dequeue> will block the -thread until another thread C<enqueue>s a scalar. - -=item dequeue_nb - -The C<dequeue_nb> method, like the C<dequeue> method, removes a scalar from -the head of the queue and returns it. Unlike C<dequeue>, though, -C<dequeue_nb> won't block if the queue is empty, instead returning -C<undef>. - -=item pending - -The C<pending> method returns the number of items still in the queue. - -=back - -=head1 SEE ALSO - -L<threads>, L<threads::shared> - -=cut - -sub new { - my $class = shift; - my @q : shared = @_; - return bless \@q, $class; -} - -sub dequeue { - my $q = shift; - lock(@$q); - cond_wait @$q until @$q; - cond_signal @$q if @$q > 1; - return shift @$q; -} - -sub dequeue_nb { - my $q = shift; - lock(@$q); - return shift @$q; -} - -sub enqueue { - my $q = shift; - lock(@$q); - push @$q, @_ and cond_signal @$q; -} - -sub pending { - my $q = shift; - lock(@$q); - return scalar(@$q); -} - -1; - - diff --git a/ext/threads/shared/shared.pm b/ext/threads/shared/shared.pm index d464caddf7..3016039b83 100644 --- a/ext/threads/shared/shared.pm +++ b/ext/threads/shared/shared.pm @@ -116,7 +116,7 @@ C<lock(\$a)> is equivalent to C<lock($a)>, while C<lock(\\$a)> is not. Note that you cannot explicitly unlock a variable; you can only wait for the lock to go out of scope. If you need more fine-grained -control, see L<threads::shared::semaphore>. +control, see L<Thread::Semaphore>. =item cond_wait VARIABLE diff --git a/installperl b/installperl index 8425f5b83e..ab59652599 100755 --- a/installperl +++ b/installperl @@ -386,6 +386,14 @@ foreach my $file (@corefiles) { } } +# Switch in the 5.005-threads versions of he threadsafe queue and semaphore +# modules if so needed. +if ($Config{use5005threads}) { + for my $m (qw(Queue Semaphore)) { + copy("ext/Thread/$m.pmx", "$installprivlib/Thread/$m.pm") + } +} + # Install main perl executables # Make links to ordinary names if installbin directory isn't current directory. diff --git a/lib/Thread/Queue.pm b/lib/Thread/Queue.pm index ebecb7433f..3b5c7c9301 100644 --- a/lib/Thread/Queue.pm +++ b/lib/Thread/Queue.pm @@ -1,44 +1,13 @@ package Thread::Queue; +use threads::shared; use strict; -our $VERSION = '1.00'; - -use Thread qw(cond_wait cond_broadcast); - -BEGIN { - use Config; - if ($Config{useithreads}) { - require 'threads/shared/queue.pm'; - for my $meth (qw(new enqueue dequeue dequeue_nb pending)) { - no strict 'refs'; - *{"Thread::Queue::$meth"} = \&{"threads::shared::queue::$meth"}; - } - } elsif ($Config{use5005threads}) { - for my $meth (qw(new enqueue dequeue dequeue_nb pending)) { - no strict 'refs'; - *{"Thread::Queue::$meth"} = \&{"Thread::Queue::${meth}_othread"}; - } - } else { - require Carp; - Carp::croak("This Perl has neither ithreads nor 5005threads"); - } -} - +our $VERSION = '2.00'; =head1 NAME -Thread::Queue - thread-safe queues (for old code only) - -=head1 CAVEAT - -For new code the use of the C<Thread::Queue> module is discouraged and -the direct use of the C<threads>, C<threads::shared> and -C<threads::shared::queue> modules is encouraged instead. - -For the whole story about the development of threads in Perl, and why you -should B<not> be using this module unless you know what you're doing, see the -CAVEAT of the C<Thread> module. +Thread::Queue - thread-safe queues =head1 SYNOPSIS @@ -46,16 +15,16 @@ CAVEAT of the C<Thread> module. my $q = new Thread::Queue; $q->enqueue("foo", "bar"); my $foo = $q->dequeue; # The "bar" is still in the queue. - my $foo = $q->dequeue_nb; # returns "bar", or undef if the queue was - # empty + my $foo = $q->dequeue_nb; # returns "bar", or undef if the queue was empty my $left = $q->pending; # returns the number of items still in the queue =head1 DESCRIPTION -A queue, as implemented by C<Thread::Queue> is a thread-safe data structure -much like a list. Any number of threads can safely add elements to the end -of the list, or remove elements from the head of the list. (Queues don't -permit adding or removing elements from the middle of the list) +A queue, as implemented by C<Thread::Queue> is a thread-safe +data structure much like a list. Any number of threads can safely +add elements to the end of the list, or remove elements from the head +of the list. (Queues don't permit adding or removing elements from +the middle of the list). =head1 FUNCTIONS AND METHODS @@ -68,7 +37,7 @@ The C<new> function creates a new empty queue. =item enqueue LIST The C<enqueue> method adds a list of scalars on to the end of the queue. -The queue will grow as needed to accomodate the list. +The queue will grow as needed to accommodate the list. =item dequeue @@ -85,45 +54,48 @@ C<undef>. =item pending -The C<pending> method returns the number of items still in the queue. (If -there can be multiple readers on the queue it's best to lock the queue -before checking to make sure that it stays in a consistent state) +The C<pending> method returns the number of items still in the queue. =back =head1 SEE ALSO -L<Thread> +L<threads>, L<threads::shared> =cut -sub new_othread { +sub new { my $class = shift; - return bless [@_], $class; + my @q : shared = @_; + return bless \@q, $class; } -sub dequeue_othread : locked : method { +sub dequeue { my $q = shift; - cond_wait $q until @$q; + lock(@$q); + cond_wait @$q until @$q; + cond_signal @$q if @$q > 1; return shift @$q; } -sub dequeue_nb_othread : locked : method { - my $q = shift; - if (@$q) { +sub dequeue_nb { + my $q = shift; + lock(@$q); return shift @$q; - } else { - return undef; - } } -sub enqueue_othread : locked : method { +sub enqueue { my $q = shift; - push(@$q, @_) and cond_broadcast $q; + lock(@$q); + push @$q, @_ and cond_signal @$q; } -sub pending_othread : locked : method { - return scalar(@{(shift)}); +sub pending { + my $q = shift; + lock(@$q); + return scalar(@$q); } 1; + + diff --git a/ext/threads/shared/t/queue.t b/lib/Thread/Queue.t index 259f7f54a4..33c420b750 100644 --- a/ext/threads/shared/t/queue.t +++ b/lib/Thread/Queue.t @@ -5,16 +5,16 @@ BEGIN { push @INC ,'../lib'; require Config; import Config; unless ($Config{'useithreads'}) { - print "1..0 # Skip: might still hang\n"; + print "1..0 # Skip: no ithreads\n"; exit 0; } } use strict; use threads; -use threads::shared::queue; +use Thread::Queue; -my $q = new threads::shared::queue; +my $q = new Thread::Queue; $|++; print "1..26\n"; diff --git a/lib/Thread/Semaphore.pm b/lib/Thread/Semaphore.pm index 51cc0c6fef..d3ebe637a7 100644 --- a/lib/Thread/Semaphore.pm +++ b/lib/Thread/Semaphore.pm @@ -1,44 +1,12 @@ package Thread::Semaphore; -use strict; - -our $VERSION = '1.00'; - -use Thread qw(cond_wait cond_broadcast); - -BEGIN { - use Config; - if ($Config{useithreads}) { - require 'threads/shared/semaphore.pm'; - for my $meth (qw(new up down)) { - no strict 'refs'; - *{"Thread::Semaphore::$meth"} = \&{"threads::shared::semaphore::$meth"}; - } - } elsif ($Config{use5005threads}) { - for my $meth (qw(new up down)) { - no strict 'refs'; - *{"Thread::Semaphore::$meth"} = \&{"Thread::Semaphore::${meth}_othread"}; - } - } else { - require Carp; - Carp::croak("This Perl has neither ithreads nor 5005threads"); - } -} +use threads::shared; +our $VERSION = '2.00'; =head1 NAME -Thread::Semaphore - thread-safe semaphores (for old code only) - -=head1 CAVEAT - -For new code the use of the C<Thread::Semaphore> module is discouraged and -the direct use of the C<threads>, C<threads::shared> and -C<threads::shared::semaphore> modules is encouraged instead. - -For the whole story about the development of threads in Perl, and why you -should B<not> be using this module unless you know what you're doing, see the -CAVEAT of the C<Thread> module. +Thread::Semaphore - thread-safe semaphores =head1 SYNOPSIS @@ -60,8 +28,8 @@ unlike locks, aren't tied to particular scalars, and so may be used to control access to anything you care to use them for. Semaphores don't limit their values to zero or one, so they can be used to -control access to some resource that may have more than one of. (For -example, filehandles) Increment and decrement amounts aren't fixed at one +control access to some resource that there may be more than one of. (For +example, filehandles). Increment and decrement amounts aren't fixed at one either, so threads can reserve or return multiple resources at once. =head1 FUNCTIONS AND METHODS @@ -80,7 +48,7 @@ number. If no number is passed, the semaphore's count is set to one. =item down NUMBER The C<down> method decreases the semaphore's count by the specified number, -or one if no number has been specified. If the semaphore's count would drop +or by one if no number has been specified. If the semaphore's count would drop below zero, this method will block until such time that the semaphore's count is equal to or larger than the amount you're C<down>ing the semaphore's count by. @@ -90,31 +58,33 @@ semaphore's count by. =item up NUMBER The C<up> method increases the semaphore's count by the number specified, -or one if no number's been specified. This will unblock any thread blocked +or by one if no number has been specified. This will unblock any thread blocked trying to C<down> the semaphore if the C<up> raises the semaphore count -above what the C<down>s are trying to decrement it by. +above the amount that the C<down>s are trying to decrement it by. =back =cut -sub new_othread { +sub new { my $class = shift; - my $val = @_ ? shift : 1; + my $val : shared = @_ ? shift : 1; bless \$val, $class; } -sub down_othread : locked : method { +sub down { my $s = shift; + lock($$s); my $inc = @_ ? shift : 1; - cond_wait $s until $$s >= $inc; + cond_wait $$s until $$s >= $inc; $$s -= $inc; } -sub up_othread : locked : method { +sub up { my $s = shift; + lock($$s); my $inc = @_ ? shift : 1; - ($$s += $inc) > 0 and cond_broadcast $s; + ($$s += $inc) > 0 and cond_broadcast $$s; } 1; diff --git a/ext/threads/shared/t/semaphore.t b/lib/Thread/Semaphore.t index 12b0a3651f..14687e0b22 100644 --- a/ext/threads/shared/t/semaphore.t +++ b/lib/Thread/Semaphore.t @@ -5,13 +5,13 @@ BEGIN { push @INC ,'../lib'; require Config; import Config; unless ($Config{'useithreads'}) { - print "1..0 # Skip: no threads\n"; + print "1..0 # Skip: no ithreads\n"; exit 0; } } print "1..1\n"; use threads; -use threads::shared::semaphore; +use Thread::Semaphore; print "ok 1\n"; diff --git a/pod/perlmodlib.pod b/pod/perlmodlib.pod index 4018041546..067f75dc5a 100644 --- a/pod/perlmodlib.pod +++ b/pod/perlmodlib.pod @@ -1009,11 +1009,11 @@ Manipulate threads in Perl (for old code only) =item Thread::Queue -Thread-safe queues (for old code only) +Thread-safe queues =item Thread::Semaphore -Thread-safe semaphores (for old code only) +Thread-safe semaphores =item Tie::Array diff --git a/pod/perlthrtut.pod b/pod/perlthrtut.pod index 6dab7ed7cb..dbc792d660 100644 --- a/pod/perlthrtut.pod +++ b/pod/perlthrtut.pod @@ -682,9 +682,9 @@ synchronization issues. They're pretty straightforward, and look like this: use threads; - use threads::shared::queue; + use Thread::Queue; - my $DataQueue = threads::shared::queue->new; + my $DataQueue = Thread::Queue->new; $thr = threads->new(sub { while ($DataElement = $DataQueue->dequeue) { print "Popped $DataElement off the queue\n"; @@ -698,7 +698,7 @@ this: $DataQueue->enqueue(undef); $thr->join; -You create the queue with C<new threads::shared::queue>. Then you can +You create the queue with C<new Thread::Queue>. Then you can add lists of scalars onto the end with enqueue(), and pop scalars off the front of it with dequeue(). A queue has no fixed size, and can grow as needed to hold everything pushed on to it. @@ -723,9 +723,9 @@ semaphore's current count would decrement below zero. This program gives a quick demonstration: use threads qw(yield); - use threads::shared::semaphore; + use Thread::Semaphore; - my $semaphore = new threads::shared::semaphore; + my $semaphore = new Thread::Semaphore; my $GlobalVariable : shared = 0; $thr1 = new threads \&sample_sub, 1; @@ -768,8 +768,8 @@ one, and up() increments by one. However, we can override any or all of these defaults simply by passing in different values: use threads; - use threads::shared::semaphore; - my $semaphore = threads::shared::semaphore->new(5); + use Thread::Semaphore; + my $semaphore = Thread::Semaphore->new(5); # Creates a semaphore with the counter set to five $thr1 = threads->new(\&sub1); @@ -882,9 +882,9 @@ things we've covered. This program finds prime numbers using threads. 4 use strict; 5 6 use threads; - 7 use threads::shared::queue; + 7 use Thread::Queue; 8 - 9 my $stream = new threads::shared::queue; + 9 my $stream = new Thread::Queue; 10 my $kid = new threads(\&check_num, $stream, 2); 11 12 for my $i ( 3 .. 1000 ) { @@ -897,7 +897,7 @@ things we've covered. This program finds prime numbers using threads. 19 sub check_num { 20 my ($upstream, $cur_prime) = @_; 21 my $kid; - 22 my $downstream = new threads::shared::queue; + 22 my $downstream = new Thread::Queue; 23 while (my $num = $upstream->dequeue) { 24 next unless $num % $cur_prime; 25 if ($kid) { diff --git a/pod/perltoc.pod b/pod/perltoc.pod index 8b0a972acf..740b0f54e3 100644 --- a/pod/perltoc.pod +++ b/pod/perltoc.pod @@ -2674,13 +2674,13 @@ Memoize::NDBM_File, Memoize::SDBM_File, Memoize::Storable, NDBM_File, NEXT, Net::Cmd, Net::Config, Net::Domain, Net::FTP, Net::NNTP, Net::Netrc, Net::POP3, Net::Ping, Net::SMTP, Net::Time, Net::hostent, Net::libnetFAQ, Net::netent, Net::protoent, Net::servent, O, ODBM_File, Opcode, POSIX, -PerlIO, Pod::Checker, Pod::Find, Pod::Functions, Pod::Html, -Pod::InputObjects, Pod::LaTeX, Pod::Man, Pod::ParseLink, Pod::ParseUtils, -Pod::Parser, Pod::Plainer, Pod::Select, Pod::Text, Pod::Text::Color, -Pod::Text::Overstrike, Pod::Text::Termcap, Pod::Usage, SDBM_File, Safe, -Search::Dict, SelectSaver, SelfLoader, Shell, Socket, Storable, Switch, -Symbol, Term::ANSIColor, Term::Cap, Term::Complete, Term::ReadLine, Test, -Test::Builder, Test::Harness, Test::Harness::Assert, +PerlIO, PerlIO::via::QuotedPrint, Pod::Checker, Pod::Find, Pod::Functions, +Pod::Html, Pod::InputObjects, Pod::LaTeX, Pod::Man, Pod::ParseLink, +Pod::ParseUtils, Pod::Parser, Pod::Plainer, Pod::Select, Pod::Text, +Pod::Text::Color, Pod::Text::Overstrike, Pod::Text::Termcap, Pod::Usage, +SDBM_File, Safe, Search::Dict, SelectSaver, SelfLoader, Shell, Socket, +Storable, Switch, Symbol, Term::ANSIColor, Term::Cap, Term::Complete, +Term::ReadLine, Test, Test::Builder, Test::Harness, Test::Harness::Assert, Test::Harness::Iterator, Test::Harness::Straps, Test::More, Test::Simple, Test::Tutorial, Text::Abbrev, Text::Balanced, Text::ParseWords, Text::Soundex, Text::Tabs, Text::Wrap, Thread, Thread::Queue, @@ -8313,37 +8313,6 @@ method, locked =back -=head2 threadshared::queue, threads::shared::queue - thread-safe queues - -=over 4 - -=item SYNOPSIS - -=item DESCRIPTION - -=item FUNCTIONS AND METHODS - -new, enqueue LIST, dequeue, dequeue_nb, pending - -=item SEE ALSO - -=back - -=head2 threadshared::semaphore, threads::shared::semaphore - thread-safe -semaphores - -=over 4 - -=item SYNOPSIS - -=item DESCRIPTION - -=item FUNCTIONS AND METHODS - -new, new NUMBER, down, down NUMBER, up, up NUMBER - -=back - =head2 threadshared::shared, threads::shared - Perl extension for sharing data structures between threads @@ -9049,8 +9018,8 @@ from perl =item DESCRIPTION $thread = threads->create(function, LIST), $thread->join, $thread->detach, -threads->self, $thread->tid, threads->yield();, threads->list();, async -BLOCK; +threads->self, $thread->tid, threads->object( tid ), threads->yield();, +threads->list();, async BLOCK; =item WARNINGS @@ -9093,37 +9062,6 @@ cond_broadcast VARIABLE =back -=head2 threadshared::queue, threads::shared::queue - thread-safe queues - -=over 4 - -=item SYNOPSIS - -=item DESCRIPTION - -=item FUNCTIONS AND METHODS - -new, enqueue LIST, dequeue, dequeue_nb, pending - -=item SEE ALSO - -=back - -=head2 threadshared::semaphore, threads::shared::semaphore - thread-safe -semaphores - -=over 4 - -=item SYNOPSIS - -=item DESCRIPTION - -=item FUNCTIONS AND METHODS - -new, new NUMBER, down, down NUMBER, up, up NUMBER - -=back - =head2 utf8 - Perl pragma to enable/disable UTF-8 (or UTF-EBCDIC) in source code @@ -18975,12 +18913,10 @@ join, eval, detach, equal, tid, flags, done =back -=head2 Thread::Queue - thread-safe queues (for old code only) +=head2 Thread::Queue - thread-safe queues =over 4 -=item CAVEAT - =item SYNOPSIS =item DESCRIPTION @@ -18993,12 +18929,10 @@ new, enqueue LIST, dequeue, dequeue_nb, pending =back -=head2 Thread::Semaphore - thread-safe semaphores (for old code only) +=head2 Thread::Semaphore - thread-safe semaphores =over 4 -=item CAVEAT - =item SYNOPSIS =item DESCRIPTION |