FPGA实战演练逻辑篇38:可综合的语法子集3
2015年06月17日 11:37 发布者:rousong1989
可综合的语法子集3本文节选自特权同学的图书《FPGA设计实战演练(逻辑篇)》配套例程下载链接:http://pan.baidu.com/s/1pJ5bCtt (1) 多语句定义:begin…end。(特权同学,版权所有)通俗的说,它就是C语言里的“{ }”,用于单个语法的多个语句定义。其使用示例如下:// 含有命名的begin语句begin : <块名> // 可选申明部分 // 具体逻辑end // 基本的begin语句begin // 可选申明部分 // 具体逻辑end(2) 比较判断:if…else, case…default…endcase。(特权同学,版权所有)判断语法if…else及case语句是最常用的功能语法,其基本的使用示例如下:// if判断语句if(<判断条件>) begin // 具体逻辑end // if…else判断语句if(<判断条件>)begin // 具体逻辑1endelse begin // 具体逻辑2end // if…else if…else判断语句if(<判断条件1>)begin // 具体逻辑1endelse if(<判断条件2>)begin // 具体逻辑2endelse begin // 具体逻辑3end // case语句case(<判断变量>)<取值1>: <具体逻辑1><取值2>: <具体逻辑2><取值3>: <具体逻辑3>default: <具体逻辑4> endcase(3) 循环语句:for。(特权同学,版权所有)用的也比较少,但也会在一些特定的设计中使用它。其示例如下:// for语句for(<变量名> = <初值>; <判断表达式>; <变量名> = <新值>)begin // 具体逻辑end(4) 任务定义:task…endtask。(特权同学,版权所有)Task更像是C语言中的子函数,task中可以有input、output和inout端口作为出入口参数,它可以用于实现一个时序控制。task没有返回值,因此不可以用在表达式中。其基本用法如下:task