<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/reference.pcre.pattern.syntax.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'zh',
  ),
  'this' => 
  array (
    0 => 'regexp.reference.anchors.php',
    1 => '锚',
    2 => '锚',
  ),
  'up' => 
  array (
    0 => 'reference.pcre.pattern.syntax.php',
    1 => 'PCRE 正则语法',
  ),
  'prev' => 
  array (
    0 => 'regexp.reference.unicode.php',
    1 => 'Unicode 字符属性',
  ),
  'next' => 
  array (
    0 => 'regexp.reference.dot.php',
    1 => '句点',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'zh',
    'path' => 'reference/pcre/pattern.syntax.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="regexp.reference.anchors" class="section">
  <h2 class="title">锚</h2>
  <p class="para">
  在一个字符类外面，在默认匹配模式下，
  脱字符（<code class="literal">^</code>） 是一个断言当前匹配点位于目标字符串开始处的断言。
   在一个字符类内部，
   脱字符（<code class="literal">^</code>） 表明这个字符类中描述的字符取反(详见下文)。
  </p>
  <p class="para">
  脱字符（<code class="literal">^</code>）并不一定要是模式的第一个字符， 但是如果处于某个可选分支时，
  它应该是该分支的首字符。如果所有选择分支都以脱字符（<code class="literal">^</code>）开头，这就是说，
  如果模式限制为只匹配目标的开头，
  它被称为是一个 ”紧固” 模式。(同样也有其他方式可以构造出紧固模式)
  </p>
  <p class="para">
  美元符(<code class="literal">$</code>)是用于断言当前匹配点位于目标字符串末尾，
  或当目标字符串以换行符结尾时当前匹配点位于该换行符位置(默认情况)。
  美元符(<code class="literal">$</code>)不一定要作为模式的最后一个字符，但是如果它在某个可选分支中时，
  就应该位于该分支的末尾。美元符在字符类中没有特殊的意义。
  </p>
  <p class="para">
  <code class="literal">$</code> 的意义可以通过在编译或匹配时设置 <a href="reference.pcre.pattern.modifiers.php" class="link">PCRE_DOLLAR_ENDONLY</a> 改变为只匹配字符串末尾。
  这不会影响 \Z 断言的行为。
  </p>
  <p class="para">
  脱字符 <code class="literal">^</code> 和美元符 <code class="literal">$</code> 字符的意义在
   <a href="reference.pcre.pattern.modifiers.php" class="link">PCRE_MULTILINE</a> 选项被设置时会发生变化。 当在这种情况下时，
  它们匹配每一个换行符后面的和前面的字符，另外，
  也会匹配目标字符串的开始和结束。比如,
  模式 /^abc$/ 在多行模式下会成功匹配目标字符串 ”def\nabc”，
  而正常情况下不会。因此，由于所有的可选分支都以 &quot;^&quot; 开始，
  在单行模式下这成为紧固模式，然而在多行模式下，这是非紧固的。
  <a href="reference.pcre.pattern.modifiers.php" class="link">PCRE_DOLLAR_ENDONLY</a>
   选项在 <a href="reference.pcre.pattern.modifiers.php" class="link">PCRE_MULTILINE</a>
   设置后失效。
  </p>
  <p class="para">
  注意： \A、\Z、
  \z 等转义序列可以在任何模式下用于匹配目标字符串的开始和结束位置。
  并且如果模式的所有分支都以 \A 开始，它同样是紧固的，
  而与 <a href="reference.pcre.pattern.modifiers.php" class="link">PCRE_MULTILINE</a>
   是否设置无关。
  </p>
 </div><?php manual_footer($setup); ?>