在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 1681|回复: 0

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

[复制链接]
发表于 2017-12-14 19:49:31 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

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

特权同学,版权所有

配套例程和更多资料下载链接:

http://pan.baidu.com/s/1i5LMUUD

1.jpg


多语句定义:beginend

通俗的说,它就是C语言里的 {  }”,用于单个语法的多个语句定义。其使用示例如下:

// 含有命名的begin语句

begin : <块名>

    // 可选申明部分

    // 具体逻辑

end


// 基本的begin语句

begin

    // 可选申明部分

    // 具体逻辑

end

比较判断:ifelse, casedefaultendcase

判断语法ifelsecase语句是最常用的功能语法,其基本的使用示例如下:

// 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

任务定义:taskendtask

Task更像是C语言中的子函数,task中可以有input、output和inout端口作为出入口参数,它可以用于实现一个时序控制。task没有返回值,因此不可以用在表达式中。其基本用法如下:

task <task命名>;

    // 可选申明部分,如本地变量申明

    begin

        // 具体逻辑

    end

endtask






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

本版积分规则

关闭

站长推荐 上一条 /2 下一条


小黑屋| 手机版| 关于我们| 联系我们| 在线咨询| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2024-12-22 20:41 , Processed in 0.026292 second(s), 9 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表