This repository has been archived on 2023-08-20. You can view files and clone it, but cannot push or open issues or pull requests.
yap-6.3/Logtalk/manuals/refman/directives/synchronized1.html

68 lines
2.8 KiB
HTML
Raw Normal View History

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"
"http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
<meta http-equiv="content-type" content="application/xml+xhtml; charset=utf-8" />
<title>Logtalk predicate directive: synchronized/1</title>
<link rel="stylesheet" href="../../screen.css" type="text/css" media="screen"/>
<link rel="stylesheet" href="../../print.css" type="text/css" media="print"/>
</head>
<body>
<div class="top-left">Logtalk reference manual</div>
<div class="top-right">Predicate directive: synchronized/1</div>
<div class="bottom-left"><span class="page"/></div>
<div class="bottom-right"><span class="page"/></div>
<div class="navtop"><a href="../../index.html">contents</a> &gt; <a href="../index.html">reference manual</a> &gt; <a href="../index.html#directives">directives</a></div>
<h2 id="directives_synchronized1" class="codenp">synchronized/1</h2>
<h4>Description</h4>
<pre>synchronized(Functor/Arity)
synchronized(Functor1/Arity1, Functor2/Arity2, ...)
synchronized([Functor1/Arity1, Functor2/Arity2, ...])
synchronized(Functor//Arity)
synchronized(Functor1//Arity1, Functor2//Arity2, ...)
synchronized([Functor1//Arity1, Functor2//Arity2, ...])</pre>
<p>
Declares synchronized predicates and synchronized grammar rule non-terminals. A synchronized predicate (or synchronized non-terminal) is protected by a mutex in order to allow for thread synchronization when proving a call to the predicate (or non-terminal). All predicates declared in the same synchronized directive share the same mutex. In order to use a separate mutex for each predicate (so that they are independently synchronized), a per-predicate synchronized directive must be used.
</p>
<p>
Synchronized predicates are silently compiled as normal predicates on Prolog compilers that don't support multi-threading programming.
</p>
<h4>Template and modes</h4>
<pre>synchronized(+predicate_indicator_term)
synchronized(+non_terminal_indicator_term)</pre>
<h4>Examples</h4>
<pre>:- synchronized(db_update/1).
:- synchronized(write_stream/2, read_stream/2).
:- synchronized([add_to_queue/2, remove_from_queue/2]).</pre>
<div class="footer">
<div class="copyright">
<span>Copyright &copy; <a href="mailto:pmoura@logtalk.org">Paulo Moura</a> &mdash; <a href="http://logtalk.org">Logtalk.org</a></span><br/>
<span>Last updated on: January 2, 2007</span>
</div>
<div class="navbottom">
<span><a href="public1.html">previous</a> | <a href="../../glossary.html">glossary</a> | <a href="uses2.html">next</a></span><br/>
<span><a href="http://validator.w3.org/check/referer">XHTML</a> + <a href="http://jigsaw.w3.org/css-validator/check/referer">CSS</a></span>
</div>
</div>
</body>
</html>