⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 00583.html

📁 这是一本关于verilog编程语言的教程,对学习verilog语言有帮助
💻 HTML
📖 第 1 页 / 共 2 页
字号:
<p class="Element10">
&nbsp;</p>
<p class="Element10">
<span style="color: #0000FF">unique</span>和<span style="color: #0000FF">priority</span>关键字适用于整个<span style="color: #0000FF">if...else...if</span>条件。在前面的例子中,在任何一个else的后面插入这两个关键字都是非法的。为了在这一系列中的条件中嵌套另外一个<span style="color: #0000FF">if</span>语句,应该使用<span style="color: #0000FF">begin</span>...<span style="color: #0000FF">end</span>块。&nbsp;</p>
<p class="Element10">
&nbsp;</p>
<p class="Element10">
在Verilog中,具有三种类型的<span style="color: #0000FF">case</span>语句,分别为<span style="color: #0000FF">case</span>、<span style="color: #0000FF">casez</span>和<span style="color: #0000FF">casex</span>。在SystemVerilog中,这三个中的任何一个都可以使用<span style="color: #0000FF">priority</span>或<span style="color: #0000FF">unique</span>限定。<span style="color: #0000FF">priority case</span>仅仅作用于第一个匹配。<span style="color: #0000FF">unique case</span>应该检查<span style="color: #0000FF">case</span>条目的交迭,允许<span style="color: #0000FF">case</span>条目能够并行计算。如果多于一个<span style="color: #0000FF">case</span>条目匹配于<span style="color: #0000FF">case</span>表达式,那么<span style="color: #0000FF">unique case</span>应该发布一条警告信息。如果<span style="color: #0000FF">case</span>被限定为<span style="color: #0000FF">priority</span>或<span style="color: #0000FF">unique</span>,那么,如果没有<span style="color: #0000FF">case</span>条目匹配的话,仿真器应该发布一条警告信息。这些警告信息可以在编译时发布也可以在运行时发布,只要仿真器能够确定这些无效条件。&nbsp;</p>
<p class="Element10">
&nbsp;</p>
<p class="Element10">
注意:通过指定<span style="color: #0000FF">unique</span>或<span style="color: #0000FF">priority</span>,我们没有必要编码一个<span style="color: #0000FF">default</span>条件来包含不期望的条件值。例如: </p><div class="Element170">
<a href="#" onclick="CopyElementToClipboard('code00266');">Copy Code</a></div>
<div class="Element13"><div class="Element12" id="code00266"><pre class="Element12"><span style="color: #0000FF">bit</span> <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> a<span style="color: #800080">;</span>

<span style="color: #0000FF">unique case</span><span style="color: #800080">(</span>a<span style="color: #800080">)</span>   <span style="color: #008000">// 值3,5,6,7会引起一个运行时警告</span>
<span style="color: #FF0000">    0</span><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">&quot;0 or 1&quot;</span><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">&quot;2&quot;</span><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">&quot;4&quot;</span><span style="color: #800080">);</span>
<span style="color: #0000FF">endcase</span>

<span style="color: #0000FF">priority</span> <span style="color: #0000FF">case</span><span style="color: #800080">(</span>a<span style="color: #800080">)</span> <span style="color: #008000">// 值4,5,6,7会引起一个运行时警告</span>
<span style="color: #FF0000">    3</span><span style="color: #800080">'</span><span style="color: #0000FF">b</span><span style="color: #FF0000">00?</span><span style="color: #800080">:</span> <span style="color: #0000FF">$display</span><span style="color: #800080">(</span><span style="color: #575D94">&quot;0 or 1&quot;</span><span style="color: #800080">);</span>
<span style="color: #FF0000">    3</span><span style="color: #800080">'</span><span style="color: #0000FF">b</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">&quot;2 or 3&quot;</span><span style="color: #800080">);</span>
<span style="color: #0000FF">endcase</span></pre></div></div>
</div>
</div>
<a name="Group"></a><div class="Element14">
<a onclick="toggleVisibilityStored('Group');" class="a_Element14"><img src="sectionminus.png" border="0" alt="" title="" id="imgGroup">Group</a></div>
<div id="divGroup">
<div class="Element11">
<div class="Element10">
<p class="Element10">
<a href="00846.html" target="topic">第八章 过程语句和控制流</a></p></div>
</div>
</div>
<a name="主题"></a><div class="Element14">
<a onclick="toggleVisibilityStored('主题');" class="a_Element14"><img src="sectionminus.png" border="0" alt="" title="" id="img主题">主题</a></div>
<div id="div主题">
<div class="Element11">
<div class="Element10">
<div class="Element212">
<div class="TableDiv">
<table cellspacing="0" class="Table0">
<tr>
<td class="Element200" valign="top" width="50%">
<div class="Element201">
主题&nbsp;</div></td><td class="Element204" valign="top" width="50%">
<div class="Element205">
描述&nbsp;</div></td></tr><tr>
<td class="Element202" valign="top" width="50%">
<div class="Element203">
<a href="00584.html" target="topic">8.4.1 模式匹配</a>&nbsp;</div></td><td class="Element206" valign="top" width="50%">
<div class="Element207">
对于将一个值与结构体、标签联合体和常量进行比较以及对它们的成员的访问来讲,模式匹配提供了一个形象而又简洁的符号。SystemVerilog为<span style="color: #0000FF">case</span>语句、<span style="color: #0000FF">if</span>语句以及条件表达式加入了模式匹配的能力。在描述那些关联文中的模式匹配之前,我们首先描述一下基本概念。<br><br>模式是在叶子上带有标识符、常量表达式、以及通配符模式“<span style="color: #800080">.*</span>”的标签联合体和结构体表达式的嵌套。对于标签联合体模式,紧跟<span style="color: #0000FF">tagged</span>关键字之后的标识符是一个联合体成员名。对于<span style="color: #0000FF">void</span>成员, 嵌套的成员模式被忽略。 &nbsp;</div></td></tr></table></div></div>
</div>
</div>
</div>
<a name="Links"></a><div class="Element14">
<a onclick="toggleVisibilityStored('链接');" class="a_Element14"><img src="sectionminus.png" border="0" alt="" title="" id="img链接">链接</a></div>
<div id="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 Page Content -->

<!-- Begin Page Footer -->
<hr width="98%" align="center" size="1" color="#CCCCCC" />
<table align="center" cellpadding="0" cellspacing="0" border="0">
	<tbody>
		<tr height="10">
			<td></td>
		</tr>
		<tr align="center">
			<td>
<script type="text/javascript"><!--
google_ad_client = "pub-5266859600380184";
google_ad_width = 468;
google_ad_height = 60;
google_ad_format = "468x60_as";
google_ad_type = "text_image";
google_ad_channel ="";
google_page_url = document.location;
//--></script>
<script type="text/javascript"
  src="http://pagead2.googlesyndication.com/pagead/show_ads.js">
</script>
			</td>
		</tr>
		<tr height="15">
			<td></td>
		</tr>
		<tr align="center">
			<td>
				<font size=2>除非特别声明,原文版权归作者所有,如有转摘请注明原作者以及译者(<a href="http://www.fpgatech.net/"  target="_blank">FPGA技术网</a>)信息。<br />
如果您对本主题有何建议或意见,请登陆<a href="http://www.fpgatech.net/forum/forumdisplay.php?fid=18" target="_blank">FPGA开发者家园</a>提交,您的参与是我们前进的动力。</font>
<script language="javascript" type="text/javascript" src="http://js.users.51.la/195685.js"></script>
<noscript><a href="http://www.51.la/?195685" target="_blank"><img alt="&#x6211;&#x8981;&#x5566;&#x514D;&#x8D39;&#x7EDF;&#x8BA1;" src="http://img.users.51.la/195685.asp" style="border:none" /></a></noscript>
			</td>
		</tr>
	</tbody>
</table>

<!-- End Page Footer -->
</div>
</div>

<!-- End Client Area -->
</body></html>

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -