当前位置: 首页 > news >正文

带地板翻转的网站怎么做百度推广教程视频教程

带地板翻转的网站怎么做,百度推广教程视频教程,深圳公司网站制作,个人工作室怎么注册关于function的应用无论是在systemverilog还是verilog中都有很广泛的应用,但是一直有一个模糊的概念困扰着我,今天刚好有时间来搞清楚并记录下来。 关于fucntion的返回值的问题: function integer clog2( input logic[255:0] value);for(cl…

关于function的应用无论是在systemverilog还是verilog中都有很广泛的应用,但是一直有一个模糊的概念困扰着我,今天刚好有时间来搞清楚并记录下来。

关于fucntion的返回值的问题:

function integer clog2( input logic[255:0] value);for(clog2 = 0; value>0; clog2= clog2+1)value = value>>1;clog2 = clog2-1;
//      param = clog2-1;
//      return 8;
endfunction
logic[3:0] param;
initial
begin$display("==========start print sim result============");$display("clog2 = %b",clog2(256'b1000));$display("============end print sim result=============");
//  $display("param = %b",param);
end

上述function vcs编译之后打印的结果为:

==========start print sim result============
clog2 = 00000000000000000000000000000011
============end print sim result=============

function中如果没有return语句(这是systemverilog增加的特性),那么默认返回与函数名相同的变量作为函数的返回值;

如果以下面的方式code:

function integer clog2( input logic[255:0] value);for(clog2 = 0; value>0; clog2= clog2+1)value = value>>1;clog2 = clog2-1;
//      param = clog2-1;return 8;
endfunction
logic[3:0] param;
initial
begin$display("==========start print sim result============");$display("clog2 = %b",clog2(256'b1000));$display("============end print sim result=============");
//  $display("param = %b",param);
end

那么编译之后打印的结果是什么呢?

==========start print sim result============
clog2 = 00000000000000000000000000001000
============end print sim result=============

看到了吧,function会以return语句声明的值作为函数的返回值;

这里还有两个小case需要注意一下,就是for()语句是连同它下面的value = value>>1;作为执行单元的,执行完了之后才会执行下一个;那行的语句。

还有这里要另外注意:

function 返回值的类型:

void:如果你想调用函数并且忽略它的返回值,可以使用void进行声明函数类型,比如函数只用来打印一些想要的信息:

function void load_array();int len = 32'b0;if(len<=0)begin$display("bad len");end// return;
endfunction 
//int arry[];
initial
begin$display("====================================");$display("this is the load array function's print");load_array();$display("====================================");//$display("load_array = %d",load_array());
end

打印结果:

====================================
this is the load array function's print
bad len
====================================

但是你如果把这句解开:

 $display("load_array = %d",load_array());

那就会报错了,因为这里使用了load_array()的返回值,但是void函数是没有返回值的。

报错:

Void functions cannot be used in contexts which require return values

 函数类型还有logic,int,static,automatic,数组,结构体等等类型;

Systemverilog中static、automatic区别_automatic变量-CSDN博客

 

http://www.hrbkazy.com/news/7288.html

相关文章:

  • 易语言网站开发教程青岛网站seo诊断
  • 用模板做网站的方法郑州搜索引擎优化公司
  • 有限公司网站建设 中企动力佛山百度搜索引擎优化的推广计划
  • 移动端网站提交提交it培训机构哪家好
  • 做政府网站排行榜qianhu微建站
  • 做网站的不给做robots文件广州seo推广运营专员
  • 北京建设工程继续教育网站深圳创新创业大赛
  • 做产地证网站怎么做网络推广赚佣金
  • 网站优化改版seo外链建设方法
  • 高端定制网站建设制作营销型网站开发公司
  • 长春网站建设q.479185700惠seo优化思路
  • 专业网站建设出售安徽百度关键词优化
  • 深圳外贸10强公司宁波seo关键词优化教程
  • 深圳大型商城网站建设企业网站优化公司
  • 无锡做网站公司哪家好企业文化
  • 小说网站 做百度联盟搜索引擎营销分析
  • 怎么样搭建wordpress河南网站建设优化技术
  • 东昌府做网站商品标题关键词优化
  • 企业做网站能赚钱么广州各区进一步强化
  • 深圳酒店网站建设百度提交入口
  • 小米发布会2023新品网站搜索引擎优化
  • 云南企业网站建设第三方平台推广引流
  • 北京中天人建设工程有限公司网站甘肃搜索引擎网络优化
  • 想做一个自己的网站怎么做的企业网站开发制作
  • 大连房地产网站开发最好的bt磁力搜索引擎
  • 如何做论坛网站营销页面
  • 厦门做外贸网站平原县网站seo优化排名
  • 整屏滚动网站百度文库首页官网
  • 毕设做网站 方面的论文新闻源
  • c 网站开发环境seo网络推广有哪些