📄 00583.html
字号:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Frameset//EN">
<html>
<head>
<title>8.4 选择语句</title>
<meta http-equiv="Content-Type" content="text/html; charset=GB2312" />
<meta name="generator" content="Doc-O-Matic" />
<meta http-equiv="Content-Style-Type" content="text/css" />
<link rel="STYLESHEET" href="default.css" type="text/css" />
<script type="text/javascript" src="scripts.js"></script>
</head>
<body class="Element700" onload="onBodyLoadEx('systemverilog31a.html', 'topic', '00583.html');" onmousedown="onBodyMouseDown();">
<!-- Begin Popups -->
<div class="Element801" id="popup00145">
<div class="Element800">
<div class="Element14">
链接</div>
<div class="Element11">
<div class="Element10">
<a href="00846.html" target="topic">第八章 过程语句和控制流</a>, <a href="00914.html" target="topic">主题</a></div>
</div>
</div>
</div>
<!-- End Popups -->
<!-- Begin Page Header -->
<div class="Element710" id="areafixed">
<div class="Element92">
<table width="100%" cellspacing="0" cellpadding="0">
<tr><td width="33%">
<div class="Element1">
<a href="#" onmousedown="showPopup(this, 'popup00145');"><img src="seealsolink.png" border="0" alt="" title=""></a> SystemVerilog 3.1a语言参考手册</div>
</td><td width="34%">
<div class="Element2">
</div>
</td><td width="33%">
<div class="Element90">
<a href="00582.html" target="topic"><img src="btn_prev_lightblue.gif" border="0" alt="Previous" title="Previous" onmouseover="switchImage(this, 'btn_prev_lightblue_hover.gif');" onmouseout="switchImage(this, 'btn_prev_lightblue.gif');"></a><a href="00846.html" target="topic"><img src="btn_up_lightblue.gif" border="0" alt="Up" title="Up" onmouseover="switchImage(this, 'btn_up_lightblue_hover.gif');" onmouseout="switchImage(this, 'btn_up_lightblue.gif');"></a><a href="00584.html" target="topic"><img src="btn_next_lightblue.gif" border="0" alt="Next" title="Next" onmouseover="switchImage(this, 'btn_next_lightblue_hover.gif');" onmouseout="switchImage(this, 'btn_next_lightblue.gif');"></a></div>
</td></tr></table><div class="Element5">
8.4 选择语句</div>
</div>
</div>
<!-- End Page Header -->
<!-- Begin Client Area -->
<div class="Element720" id="areascroll">
<div class="Element721">
<!-- Begin Page Content -->
<div class="Element58">
<a name="描述"></a><div class="Element11">
<div class="Element10">
<div class="Element170">
<a href="#" onclick="CopyElementToClipboard('code00264');">Copy Code</a></div>
<div class="Element13"><div class="Element12" id="code00264"><pre class="Element12">conditional_statement ::= <span style="color: #008000">// 引用自附录A.6.6</span>
<strong><span style="color: #FF0000">if</span></strong> <strong><span style="color: #FF0000">(</span></strong>cond_predicate<strong><span style="color: #FF0000">)</span></strong> statement_or_null [<strong><span style="color: #FF0000">else</span></strong> statement_or_null]
| unique_priority_if_statement
unique_priority_if_statement ::=
[unique_priority] <strong><span style="color: #FF0000">if</span></strong> <strong><span style="color: #FF0000">(</span></strong>cond_predicate<strong><span style="color: #FF0000">)</span></strong> statement_or_null
{<strong><span style="color: #FF0000">else if (</span></strong>cond_predicate<strong><span style="color: #FF0000">)</span></strong> statement_or_null}
[<strong><span style="color: #FF0000">else</span></strong> statement_or_null]
unique_priority ::= <strong><span style="color: #FF0000">unique</span></strong> | <strong><span style="color: #FF0000">priority</span></strong>
cond_predicate ::=
expression_or_cond_pattern {<strong><span style="color: #FF0000">&&</span></strong> expression_or_cond_pattern}
expression_or_cond_pattern ::=
expression | cond_pattern
cond_pattern ::= expression <strong><span style="color: #FF0000">matches</span></strong> pattern
case_statement ::= <span style="color: #008000">// 引用自附录 A.6.7</span>
[unique_priority]case_keyword<strong><span style="color: #FF0000">(</span></strong>expression<strong><span style="color: #FF0000">)</span></strong> case_item {case_item} <strong><span style="color: #FF0000">endcase</span></strong>
| [unique_priority]case_keyword<strong><span style="color: #FF0000">(</span></strong>expression<strong><span style="color: #FF0000">)</span></strong> <strong><span style="color: #FF0000">matches</span></strong> case_pattern_item {case_pattern_item}
<strong><span style="color: #FF0000">endcase</span></strong>
case_keyword ::= <strong><span style="color: #FF0000">case</span></strong> | <strong><span style="color: #FF0000">casez</span></strong> | <strong><span style="color: #FF0000">casex</span></strong>
case_item ::=
expression {<strong><span style="color: #FF0000">,</span></strong>expression} <strong><span style="color: #FF0000">:</span></strong> statement_or_null
| <strong><span style="color: #FF0000">default</span></strong> [<strong><span style="color: #FF0000">:</span></strong>] statement_or_null
case_pattern_item ::=
pattern [<strong><span style="color: #FF0000">&&</span></strong>expression ] <strong><span style="color: #FF0000">:</span></strong> statement_or_null
| <strong><span style="color: #FF0000">default</span></strong> [<strong><span style="color: #FF0000">:</span></strong>] statement_or_null</pre></div></div>
<p class="Element10" style="text-align: center">
<strong>语法 8-3—选择语句语法(摘录自附录A)</strong></p><p class="Element10">
</p>
<p class="Element10">
在Verilog中,<span style="color: #0000FF">if</span> <span style="color: #800080">(<i></span>expression<span style="color: #800080"></i>)</span> 被计算成一个布尔值,因此,如果表达式的值是<span style="color: #FF0000">0</span>或<span style="color: #FF0000">X</span>,那么条件检查被认为是“假”的。 </p>
<p class="Element10">
</p>
<p class="Element10">
SystemVerilog加入了关键字<span style="color: #0000FF">unique</span>和<span style="color: #0000FF">priority</span>,它们可以在<span style="color: #0000FF">if</span>之前使用。除非有一个显式的<span style="color: #0000FF">else</span>语句,在没有条件匹配的情况下,只要使用了这两个关键字,就会引起运行时错误。例如: </p><div class="Element170">
<a href="#" onclick="CopyElementToClipboard('code00265');">Copy Code</a></div>
<div class="Element13"><div class="Element12" id="code00265"><pre class="Element12"><span style="color: #0000FF">unique if</span> <span style="color: #800080">((</span>a<span style="color: #800080">==</span><span style="color: #FF0000">0</span><span style="color: #800080">) || (</span>a<span style="color: #800080">==</span><span style="color: #FF0000">1</span><span style="color: #800080">))</span> <span style="color: #0000FF">$display</span><span style="color: #800080">(</span><span style="color: #575D94">"0 or 1"</span><span style="color: #800080">);</span>
<span style="color: #0000FF">else if</span> <span style="color: #800080">(</span>a <span style="color: #800080">== </span><span style="color: #FF0000">2</span><span style="color: #800080">)</span> <span style="color: #0000FF">$display</span><span style="color: #800080">(</span><span style="color: #575D94">"2"</span><span style="color: #800080">);</span>
<span style="color: #0000FF">else if</span> <span style="color: #800080">(</span>a <span style="color: #800080">== </span><span style="color: #FF0000">4</span><span style="color: #800080">)</span> <span style="color: #0000FF">$display</span><span style="color: #800080">(</span><span style="color: #575D94">"4"</span><span style="color: #800080">);</span> <span style="color: #008000">// 值3,5,6,7会引起一个错误</span>
<span style="color: #0000FF">priority if</span> <span style="color: #800080">(</span>a<span style="color: #800080">[</span><span style="color: #FF0000">2</span><span style="color: #800080">:</span><span style="color: #FF0000">1</span><span style="color: #800080">]==</span><span style="color: #FF0000">0</span><span style="color: #800080">)</span> <span style="color: #0000FF">$display</span><span style="color: #800080">(</span><span style="color: #575D94">"0 or 1"</span><span style="color: #800080">);</span>
<span style="color: #0000FF">else</span> <span style="color: #0000FF">if</span> <span style="color: #800080">(</span>a<span style="color: #800080">[</span><span style="color: #FF0000">2</span><span style="color: #800080">]==</span><span style="color: #FF0000">0</span><span style="color: #800080">)</span> <span style="color: #0000FF">$display</span><span style="color: #800080">(</span><span style="color: #575D94">"2 or 3"</span><span style="color: #800080">);</span>
<span style="color: #0000FF">else</span> <span style="color: #0000FF">$display</span><span style="color: #800080">(</span><span style="color: #575D94">"4 or 7"</span><span style="color: #800080">);</span> <span style="color: #008000">// 覆盖了所有可能的其他值,因此没有错误。</span></pre></div></div>
<p class="Element10">
<span style="color: #0000FF">unique if</span>指示在一系列 <span style="color: #0000FF">if...else...if</span>条件中不应该有任何交迭,也就是说,这些条件是互斥的,这就使得表达式能够并行计算。如果软件工具发现有多于一个条件为“真”,那么它应该发布一条错误信息。另外,如果软件工具发现没有条件为“真”,或者可能没有条件为“真”,并且最后的<span style="color: #0000FF">if</span>没有对应的<span style="color: #0000FF">else</span>语句,软件工具也应该发布一条错误信息。 </p>
<p class="Element10">
</p>
<p class="Element10">
<span style="color: #0000FF">priority if</span>指示一系列<span style="color: #0000FF">if...else...if</span>条件应该按列出的顺序计算。在前面的例子中,如果变量<i>a</i>的值为<span style="color: #FF0000">0</span>,那么它可以满足第一个条件和第二个条件,这就要求一个优先级逻辑。如果软件工具发现没有条件为“真”,或者可能没有条件为“真”,并且最后的<span style="color: #0000FF">if</span>没有对应的<span style="color: #0000FF">else</span>语句,软件工具也应该发布一条错误信息。 </p>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -