我是靠谱客的博主 昏睡冷风,最近开发中收集的这篇文章主要介绍Verilog基础语法--数据类型【常用的几种】,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

一、概述

先介绍四个最基本的类型:reg、wire、integer、parameter;除了这四个之外,还有其他诸多类型可参考夏宇闻的Verilog数字系统设计第二版,这些数据类型除了time外都和基本逻辑单元库有关,该库是由半导体厂家和EDA工具厂家共同提供的。

二、常量

  1. 数字类型:
    整数: 二、八、十、十六进制
    x和z: x表不定态,z表高阻态还可以用?来表达,在case语句中建议用?写法来提高程序可读性
    负数: 比如-8’d5
    下划线: 比如:8’b000_0001以此提高可读性

  2. 参数(parameter)类型:
    用来定义常量的,通过一个标识符来代表一个常量,例如: parameter A = 3’b001; 那么在这个module中A的值就代表二进制001;

  3. 变量
    wire/tri: wire通常使用assign语句实现(组合逻辑的描述),定义的方式:例如wire [3:0] state; 即wire型变量state的为位宽是4位。
    关于wire/tri真值表如下:
    在这里插入图片描述
    reg: 寄存器数据类型变量的关键字,reg型数据通常在always块中使用,定义方式和wire的一致。注:reg型数据默认初始值是不定值。如果reg值是一个无符号数,即该数的本身,若是有符号的话则认为是其补码+1,例如一个reg型数据被赋值为4,那么就是4,如果被赋值为-1,那么在运算时被认为是+15。
    memory: 类似于C语言中的数组,可用来对存储器建模,如:RAM、ROM等。定义方式如:reg [7:0] mema [255:0],定义了一个mema存储器,存入的数据位宽是8bit,存储器的深度是256。索引的方式如:mema[3]=0,即对存储器mema的第三个单元进行操作。

最后

以上就是昏睡冷风为你收集整理的Verilog基础语法--数据类型【常用的几种】的全部内容,希望文章能够帮你解决Verilog基础语法--数据类型【常用的几种】所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(41)

评论列表共有 0 条评论

立即
投稿
返回
顶部