VHDL语言 怎么理解并行语句和PROCESS的区别 IF怎么用 求详解 可以追加

 我来答
龙薇公主
2011-10-03
知道答主
回答量:25
采纳率:0%
帮助的人:24.1万
展开全部
不是很理解你的问题。首先结构体(ARCHITECTURE)中,BEGIN和END之间的部分是并行处理语句部分。它包括5种:块语句、进程语句(PROCESS)、信号赋值语句(定义信号的)、子程序调用语句和元件例化语句(这个我也不太清楚)。通常结构体中采用的3种子结构为:块语句结构(BLOCK)、进程(PROCESS)结构和子程序(SUBPROGRAM)结构。然后结构体中所有的处理语句都是并发执行的,所以叫做并行语句。只有进程语句中的语句是顺序语句。就是说一个结构体可以包括多个PROCESS,它们之间是并发执行的,而每个PROCESS内部是顺序执行的。
不知道是不是你想要的答案。
至于IF语句,我觉得和C++什么的差不多呢。就是
IF(条件)THEN
(顺序语句);
ELSIF(条件)THEN
(顺序语句);
……
ELSE
(顺序语句);
END IF;
建议你弄本书来看啊,VHDL其实还是蛮复杂的,老师说会越来越觉得复杂的~
追问
谢谢你的回答,我刚刚开始i学,有书,老师放假了,我一个看书,有些地方还不是很明白,也表达不清楚,不过还是谢谢你    我就是不太理解  这个并行语句是怎么个并行法  和 C的逐句执行怎么区分。。
追答
并行就是不分先后,可以一起执行吧。我觉得就只有PROCESS里的语句和C类似。举个例子吧。比如hafl-adder的结构体。
可以有3个方法来表述。
1.PROCESS
ARCHITECTURE half_adder_a OF half_adder IS
BEGIN
PROCESS(x,y,enable)
BEGIN
IF enable='1' THEN
result<= x XOR y;
carry<= x AND y;
ELSE
carry<='0';
result<='0';
END IF;
END PROCESS;
END half_adder_a;
像这个就必须逐行执行。
2.use logic equation
ARCHITECTURE half_adder_a OF half_adder IS
BEGIN
carry<=enable AND (x and y);
result<=enable AND (x xor y);
END half_adder_b;
3.created from predescribed components.
这个内容比较多。和2一样,也是可以并发执行的。其实就是一块一块的,然后这些块可以一起执行。但是想IF语句这样的,就只能以PROCESS的形式出现。
595640376
推荐于2017-09-29
知道答主
回答量:7
采纳率:0%
帮助的人:6.8万
展开全部
并行语句可以理解为 好多个逻辑电路一起进行数据处理 而不是单片机那种一环一环 需要前面的语句处理完了 才能处理后面的语句, process就是一个个程序快 相当于一个个电路快一个电路块是一个process process里面是逻辑电路或时序电路 if的用法注意就是一定要在时序电路中才能用 就是一定在process里面才行
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式