Difference between revisions of "Ns critsec"
Jump to navigation
Jump to search
(Added multiple sequential calls to ns_critsec enter to the example) |
m |
||
Line 23: | Line 23: | ||
: Enters the critical section. The thread will block if another thread is already in the critical section. | : Enters the critical section. The thread will block if another thread is already in the critical section. | ||
− | * '''ns_critsec | + | * '''ns_critsec leave''' ''object'' |
: Leaves the critical section. When the thread leaves the critical section as many times as it has entered, a notification will be sent to other threads that are waiting on the critical section. | : Leaves the critical section. When the thread leaves the critical section as many times as it has entered, a notification will be sent to other threads that are waiting on the critical section. |
Latest revision as of 15:39, 29 August 2008
Man page: http://aolserver.com/docs/tcl/ns_critsec.html
NAME
- ns_critsec - Operate on critical section objects
SYNOPSIS
- ns_critsec option ?arg arg ...?
DESCRIPTION
- This command provides a mechanism to manipulate critical section objects. The legal options (which may be abbreviated) are:
- ns_critsec create
- Initializes a new critical section object and returns a handle to it.
- ns_critsec destroy object
- Destroys the critical section object and frees any resources it was using.
- ns_critsec enter object
- Enters the critical section. The thread will block if another thread is already in the critical section.
- ns_critsec leave object
- Leaves the critical section. When the thread leaves the critical section as many times as it has entered, a notification will be sent to other threads that are waiting on the critical section.
EXAMPLES
Is this the right way to use this command? The example is contrived, but I wanted to call ns_critsec multiple times.
# If a thread is executing any of these procs, no other # thread can execute any of these procs until the first # thread has completely finished. nsv_set . special_file_critsec [ns_critsec create] proc write_special_file {data} { set critsec [nsv_get . special_file_critsec] ns_critsec enter $critsec set handle [open special_file w] puts $handle $data close $handle ns_critsec leave $critsec } proc read_special_file {} { set critsec [nsv_get . special_file_critsec] ns_critsec enter $critsec set handle [open special_file r] set result [read $handle] close $handle ns_critsec leave $critsec return $result } proc change_special_file {data} { set critsec [nsv_get . special_file_critsec] ns_critsec enter $critsec set result [read_special_file] write_special_file $data ns_critsec leave $critsec return $result }
SEE ALSO