📄 00560.html
字号:
为了处理成员具有不同类型的问题,我们可以使用一个类型作为键值。它会过载该类型成员的缺省值: </p><div class="Element170">
<a href="#" onclick="CopyElementToClipboard('code00233');">Copy Code</a></div>
<div class="Element13"><div class="Element12" id="code00233"><pre class="Element12"><span style="color: #0000FF">typedef struct</span> <span style="color: #800080">{</span>
<span style="color: #0000FF">logic</span> <span style="color: #800080">[</span><span style="color: #FF0000">7</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">bit</span> b<span style="color: #800080">;</span>
<span style="color: #0000FF">bit signed</span> <span style="color: #800080">[</span><span style="color: #FF0000">31</span><span style="color: #800080">:</span><span style="color: #FF0000">0</span><span style="color: #800080">]</span> c<span style="color: #800080">;</span>
<span style="color: #0000FF">string</span> s<span style="color: #800080">;</span>
<span style="color: #800080">}</span> sa<span style="color: #800080">;</span>
sa s2<span style="color: #800080">;</span>
<span style="color: #0000FF">initial begin</span>
s2 <span style="color: #800080">=</span> <span style="color: #800080">{</span><span style="color: #0000FF">int</span><span style="color: #800080">:</span><span style="color: #FF0000">1</span><span style="color: #800080">,</span> <span style="color: #0000FF">default</span><span style="color: #800080">:</span><span style="color: #FF0000">0</span><span style="color: #800080">,</span> <span style="color: #0000FF">string</span><span style="color: #800080">:</span><span style="color: #575D94">""</span><span style="color: #800080">};</span> <span style="color: #008000">// 除了将位数组设置成1以及将字符串设置成</span>
<span style="color: #008000"> // ""之外,所有其它成员均设置成0。</span>
<span style="color: #0000FF">end</span></pre></div></div>
<p class="Element10">
类似的,我们可以设置单个成员以便过载由<span style="color: #0000FF">default</span>和类型缺省设置的值: </p><div class="Element170">
<a href="#" onclick="CopyElementToClipboard('code00234');">Copy Code</a></div>
<div class="Element13"><div class="Element12" id="code00234"><pre class="Element12"><span style="color: #0000FF">initial</span> <span style="color: #800080">#</span><span style="color: #FF0000">10</span> s1 <span style="color: #800080">=</span> <span style="color: #800080">{</span><span style="color: #0000FF">default</span><span style="color: #800080">:'</span><span style="color: #FF0000">1</span><span style="color: #800080">,</span> s<span style="color: #800080">:</span><span style="color: #575D94">""</span><span style="color: #800080">};</span> <span style="color: #008000">// 除了s设置为""之外,所有其它成员均设置成1</span></pre></div></div>
<p class="Element10">
当花括号使用在一条赋值语句的关联文中的时侯,由SystemVerilog确定花括号的关联文。如果花括号使用在一条对非压缩结构体赋值的关联文中,那么花括号代表一个非压缩数组文本或表达式。在对一个集合类型赋值的关联文之外,花括号必须与一个显式的强制类型转换一起使用以便将它与串联区分开来。当花括号包含了一个标签、类型或<span style="color: #0000FF">default</span>键值的时候,无论对于压缩结构体类型还是非压缩结构体类型,花括号都不应被解释成串联。 </p>
<p class="Element10">
</p>
<p class="Element10">
匹配规则如下:</p>
<ul class="Element630">
<li class="Element600"><i>member<span style="color: #800080"></i>:<i></span>value</i>:为结构体的一个命名成员显式地指定一个确定的值。这个命名成员必须位于结构体的顶层,也就是说位于某个子结构体中具有相同名字的成员不会被设置。这个指定的值必须能够被强制转换到成员类型,并在为命名成员赋值的关联文中计算,否则会产生一个错误。</li>
<li class="Element600"><i>type<span style="color: #800080"></i>:<i></span>value</i>:如果结构体中的一个域没有使用上述的域名键值设置,那么可以使用<i>type<span style="color: #800080"></i>:<i></span>value</i>为结构体中等价于指定类型的域指定一个确切的值。如果指定了多个相同的类型键值,那么使用最后一个类型键值。这个值在为匹配类型成员赋值的关联文中计算。</li>
<li class="Element600"><span style="color: #0000FF">default</span><span style="color: #800080">:<i></span>value</i>:应用于没有通过成员名或类型键值匹配,并且不是结构体或非压缩数组的成员。值在对通过<span style="color: #0000FF">default</span>匹配的成员的每一个赋值中计算,并且必须能够被强制转换到成员的类型,否则会产生一个错误。对于未匹配的结构体成员,类型和<span style="color: #0000FF">default</span>说明符根据本节中的规则递归地应用到每一个子结构体的成员。对于未匹配的非压缩数组成员,类型和<span style="color: #0000FF">default</span>说明符根据非压缩数组规则应用到这个数组。</li>
</ul><p class="Element10">
每一个成员都必须被其中的一个规则所涵盖。 </p>
<p class="Element10">
</p>
<p class="Element10">
如果一个类型键值、<span style="color: #0000FF">default</span>键值、或者复制操作符被使用在一个具有副作用的表达式中,那么表达式的计算次数是为定义的。</p></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="00860.html" target="topic">第七章 操作符与表达式</a></p></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="00860.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="我要啦免费统计" 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 + -