verilog 中啥语句并行运行啥时候顺序运行!搞不懂 请教高手!

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了verilog 中啥语句并行运行啥时候顺序运行!搞不懂 请教高手!相关的知识,希望对你有一定的参考价值。

所有的always块是并行的,达到触发就运行,assign也是,beign-end中是顺序,但这个所谓的顺序也是需要看实际情况,所以很多在begin-end中依然用if-else或case来解决,verilog重要的是时序,你可以在编完程序后做波形图来看,重点是上升沿下降沿等变化和赋值,可以用功能仿真来观察时序效果 参考技术A 不能单纯的看语言,看到语言应该想到相应的硬件才可以。
加入两个电路模块a和b,a中输出的信号送到b的输入,也就是b需要a先得出这个信号,那么在语言中,就是顺序的。反之,如果a,b两个模块的输入和输出之间的信号没有什么联系,就可以说二者在语言上是并行执行的。举个例子吧
begin
//顺序的,c的赋值在a之后。
a=~b;
c=~a;
end
begin
//并行的,a与c是同时赋值的
a=~b;
c=b;
end
个人理解,仅供参考!
参考技术B 你好!
initial中的语句顺序运行,其他都是并行执行的。应该区分并行与timing先后的概念。
尽量不要在一个always对多个寄存器赋值,这样你就搞清楚了,不同的always和assign语句之间都是并行的
如有疑问,请追问。
参考技术C initial中的语句顺序运行,其他都是并行执行的。应该区分并行与timing先后的概念。
尽量不要在一个always对多个寄存器赋值,这样你就搞清楚了,不同的always和assign语句之间都是并行的

请问HTML标签中啥时候用NAME,啥时候用ID,请通俗举例说明。还有JAVASCRIPT中啥时候用THROW语句?

一个大疑惑:ID是交谁处理?NAME是由处理??我只知道ID是客户端元素,NAME是提交表单时才用。

id与name的作用,作为标签的标识符,基本上是一样的.name是老方法,id是在name基础上发明的,后来才有的,"现代化"一点,用的范围广一点. <A..> 中的name原来(刚发明时)就是用于本页揿一下转向过去用的.

除 BASE, HEAD, HTML, META, SCRIPT, STYLE, TITLE 标签外,id 都可用.

name只用于APPLET,SELECT,FORM,FRAME,IFRAME,IMG,A,INPUT,OBJECT,MAP,PARAM,META. (name有时有自己的用途)

table 中 name 无定义, 应当用 id.

有些标签,可以同时有name和id.

在一个HTML网页中,id是唯一的,即只有某一个标签,或某一个块的标识符是这个id.

id 在HTML中的作用:

(1) 用id选择相应的style sheet(风格).
(2) <A ..> 链接的目的地
(3) 脚本语言用它找目的地(找该id的标签)
(4) 作为名字,用于声明某OBJECT element
(5) 作为一个标签或块的区分标致(用于从HTML网页中取出数据放入数据库或把HTML翻译成别的格式,等情况).

(参考HTML 4.0 定义)

JavaScript 异常 使用throw语句抛出异常顾名思义,就是超出常规
js的异常是在运行过程中发生的错误,如果您学过java中的异常,会知道这叫做runtime exception,那么什么是js异常呢?在代码的运行过程中,错误是不可避免的,总的来说,错误发生于两种情况:一是程序内部的逻辑或者语法错误,二是运行环境或者用户输入中不可预知的数据造成的错误。对于前者,就称之为错误(error),可以通过调试程序来解决;而后一种则更多的称之为异常(exception),顾名思义,就是超出常规,没有按程序设计的意愿来输入数据。当然,异常还会有许多种类型。
所以说,异常并不等价于错误,相反,有时还会利用异常来解决一些问题。JavaScript可以捕获一个异常并进行相应的处理,从而避免了浏览器向用户报错。

使用try-catch-finally处理异常
用户可以使用该结构处理可能发生异常的代码,如果发生异常,则由catch捕获并进行处理,其语法如下:
try
//要执行的代码

catch(e)
//处理异常的代码

finally
//无论异常发生与否,都会执行的代码

通过异常处理,可以避免程序停止运行,从而具有了一定的自我修复能力。
在Ajax开发中,利用异常处理的一个典型应用就是创建XMLHttpRequest对象,不同浏览器创建它的方式是不一样的,为了使代码能够跨浏览器运行,就可以利用异常,一种方法不行,再用另一种方法,直到不发生异常为止,例如:
<script language=”JavaScript” type=”text/javascript”>
<!–
var xmlhttp;
try
//尝试用IE浏览器的方式创建XMLHttpRequest对象
xmlhttp=new ActiveXObject(”Microsoft.XMLHTTP”);
catch(e)
try
//尝试用非IE浏览器的方式常见XMLHttpRequest对象
xmlhttp=new XMLHttpRequest();
catch(e)

//–>
</script>
通过这种方式,就可以跨浏览器创建XMLHttpRequest对象。注意,即使不在catch块内进行处理,catch标识及其参数e也是必须写的,否则会产生语法错误,而finnally则不是必须的。

使用throw语句抛出异常

在JavaScript中有其内部的异常机制,在遇到非法操作时能自动抛出异常。实际的开发中,随着程序的复杂,需要能自己实现异常,这可以通过throw语句来实现:
throw value;
其中value就是要抛出的异常变量,它可以是JavaScript中的任何一种类型(相当于自定义异常)。但在JavaScript内部的异常中,异常参数(即catch (e)中的e)是一个名为error的对象,可以通过new Error(message)来创建这个对象,异常的描述被作为error对象的一个属性message,可以由构造函数传入,也可以之后赋值。通过这个异常描述message,可以让程序获取异常的详细信息,从而自动处理。
下面的程序计算两个数据的和,如果参数不是数字,则抛出异常,代码如下:
<script language=”JavaScript” type=”text/javascript”>
<!–
//函数默认要求参数为数字
function sum(a,b)
a=parseInt(a);
b=parseInt(b);
//如果a或b不能转换为数字则抛出一个异常对象
if(isNaN(a) || isNaN(b))
throw new Error(”arguments are not numbers”);

return a+b;


try
//错误的调用
var s=sum(”c”,”d”);
catch(e)
//显示异常的详细信息
alert(e.message);

//–>
</script>
程序中使用字母作为参数传递给sum函数,是错误的,所以函数内抛出了一个异常对象,这个对象被catch语句获取,并使用alert语句显示了其详细信息。
注意:使用new Error(message)创建异常对象只是一种默认的习惯,也是内置异常的实现方式。这不是必需的,完全可以抛出任意数据类型的异常,例如一个整数,来作为异常的描述。只要在程序中抛出异常和捕获异常能匹配即可。

Error对象除了message属性以外,还有一些其他的属性,这些属性因浏览器而异,例如:在IE浏览器中,error对象的属性包括 name、 number、description、message;而在Firefox浏览器中,error对象的属性包括message、fileName、 lineNumber、stack、name。在实际的应用中如果要实现自己的异常,这些属性只要被赋值,都是可用的,其中Firefox浏览器还会自动对stack属性赋值,用于显示异常出现的位置。

JavaScript 内置的7个异常

Error

SyntaxError

TypeError

RangeError

EvalError

ReferenceError

URIError

部分来自baidu

javascript用法:break,continue和return语句
2009-02-05 22:17
break,continue和return这三个语句的用法新手们经常弄混淆,至少在我学习C语言的时候经常把它们的用法给搞错。不过现在好了,我已彻底搞清楚它们之间的用法!!由于最近一直在看javascript,下面简要说一下它们三个在javascript的一些用法

break语句:
break语句会使运行的程序立刻退出包含在最内层的循环或者退出一个switch语句。由于它是用来退出循环或者switch语句,所以只有当它出现在这些语句时,这种形式的break语句才是合法的。

如果一个循环的终止条件非常复杂,那么使用break语句来实现某些条件比用一个循环表达式来表达所有的条件容易得多。

<script type="text/javascript">
for(var i=1;i<=10;i++)
if(i==6) break;
document.write(i);

//输出结果:12345
</script>

continue语句:
continue语句和break语句相似。所不同的是,它不是退出一个循环,而是开始循环的一次新迭代。

continue语句只能用在while语句、do/while语句、for语句、或者for/in语句的循环体内,在其它地方使用都会引起错误!

<script type="text/javascript">
for(var i=1;i<=10;i++)
if(i==6) continue;
document.write(i);

//输出结果:1234578910
</script>

return语句:
return语句就是用于指定函数返回的值。return语句只能出现在函数体内,出现在代码中的其他任何地方都会造成语法错误!
当执行return语句时,即使函数主体中还有其他语句,函数执行也会停止!

参考资料:http://hi.baidu.com/hjzheng/blog/item/61bb7327963349134d088d28.html

参考技术A 楼上说的很对哦,并且id可以在对很多元素下作为唯一标示出现,比如<tr></tr>,当你需要对此行进行一个JS编辑时,就可以直接给他加一个id,但是加不了name;
一般的控件可以加name和id两种标示,并且命名不同,那么你在JS编写的时候,就可以分别根据name和ID来做,这样有时候自己会比较方便
参考技术B ID就相当于身份证的编码,正确的规则只有一个。只能匹配一个
Name就相当于你身份证上的名字,可以跟别人重合。

比如:单选框、复选框 就会用到相同的NAME。
参考技术C id是唯一属性,name是普通属性的。
2个区别不大,都是用来标识元素的。
用js取得时候会有区别 document.getElementById("id");
document.getElementsByName("name");

js中一般不用throw。
参考技术D name 我不怎么用
任意位置<a href="#qan">头部</a>
任意位置<a name="qan">底部</a>
单击底部直接跳转到头部位置

id是接css类的
<style>
#qabackground:#ccc; width:200px; height:200px /*背景颜色为#ccc*/
.ccolor:red
</style>
<div id="qa" class="c">字体是红色的</div>

js同楼上
document.getElementById("dashu");
来获取body中id为dashu的属性
name类似本回答被提问者采纳

以上是关于verilog 中啥语句并行运行啥时候顺序运行!搞不懂 请教高手!的主要内容,如果未能解决你的问题,请参考以下文章

verilog语句执行顺序的疑问?

java中啥叫做线程?啥叫多线程?多线程的特点是啥

请问HTML标签中啥时候用NAME,啥时候用ID,请通俗举例说明。还有JAVASCRIPT中啥时候用THROW语句?

FPGA学习----Verilog HDL语法

在 verilog中的非阻塞赋值在啥时候赋值时刻结束?

在java程序中啥条件下要用import语句?啥时候不用?