OpenEdv-开源电子网

 找回密码
 立即注册

扫一扫,访问微社区

正点原子新作:阿波罗STM32F767&F429&探索者STM32F4开发板&赶快来下载资料哦。

查看: 821|回复: 0
打印 上一主题 下一主题

勇敢的芯伴你玩转Altera FPGA连载32:可综合的语法子集3

[复制链接]

  离线 

328

主题

335

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1463
金钱
1463
注册时间
2014-7-19
在线时间
33 小时
跳转到指定楼层
楼主
发表于 2017-12-14 20:00:58 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式
正点原子公众号
勇敢的芯伴你玩转Altera FPGA连载32:可综合的语法子集3
特权同学,版权所有
配套例程和更多资料下载链接:
http://pan.baidu.com/s/1i5LMUUD
多语句定义:begin…end
通俗的说,它就是C语言里的 “{  }”,用于单个语法的多个语句定义。其使用示例如下:
// 含有命名的begin语句
begin : <块名>
    // 可选申明部分
    // 具体逻辑
end
// 基本的begin语句
begin
    // 可选申明部分
    // 具体逻辑
end
比较判断:if…else, case…default…endcase
判断语法if…else及case语句是最常用的功能语法,其基本的使用示例如下:
// if判断语句
if(<判断条件>)
begin
    // 具体逻辑
end
// if…else判断语句
if(<判断条件>)
begin
    // 具体逻辑1
end
else
begin
    // 具体逻辑2
end
// if…else if…else判断语句
if(<判断条件1>)
begin
    // 具体逻辑1
end
else if(<判断条件2>)
begin
    // 具体逻辑2
end
else
begin
    // 具体逻辑3
end
// case语句
case(<判断变量>)
<取值1>: <具体逻辑1>
<取值2>: <具体逻辑2>
<取值3>: <具体逻辑3>
default: <具体逻辑4>
endcase
循环语句:for
用的也比较少,但也会在一些特定的设计中使用它。其示例如下:
// for语句
for(<变量名> = <初值>; <判断表达式>; <变量名> = <新值>)
begin
    // 具体逻辑
end
任务定义:task…endtask
Task更像是C语言中的子函数,task中可以有input、output和inout端口作为出入口参数,它可以用于实现一个时序控制。task没有返回值,因此不可以用在表达式中。其基本用法如下:
task <task命名>;
    // 可选申明部分,如本地变量申明
    begin
        // 具体逻辑
    end
endtask


回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则




QQ|联系我们|手机版|官方淘宝店|新浪微博|微信公众平台|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2018-1-24 09:50

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表
/* */