首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

易语言 取自定义数据类型的大小

先说一下易语言的变量储存机制 易语言有基本数据类型和复合数据类型两种 基本数据类型包括:1. 各种整数 2.各种浮点 3. 逻辑值 他们都是储存在栈上的 大小都是固定的 用不着取 复合类型一般储存在堆上 然后在栈上储存堆上数据的引用 其中有几种比较特殊:字符串 字节集 数组 这两种类型的大小虽然储存在堆上的某个地方 但都有专门的取大小函数 直接调用即可 剩下就是自定义数据类型 比如类或者结构 特别是类 类的数据成员都是私有的 假如你想知道别人写的一个模块里一个类的大小 不可能通过数数据成员的方法得到 那如何取到呢?有人可能提出用“取变量地址”这个函数 可惜的是 “取变量地址”取到的永远是栈上的地址 根据上面所说 栈上地址的内容就是堆上地址 但是易语言没有一个用指针取整数的函数 这就需要用一个系统api:RtlMoveMemory 这个函数跟c语言memcpy的功能一样 但是有了他问题就变得容易的多 声明一个整形变量a  ls是一个自定义的类或者结构 RtlMoveMemory (取变量地址 (a), 取变量地址 (LS), 4) 这样a储存的就是ls在堆区的地址 之后用到一个api:LocalSize 我们都知道堆区内存分配必然用到LocalAlloc/GlobalAlloc 那么也能通过LocalSize取到大小 调试输出 (LocalSize (a)) 之后这样输出的就是ls的大小 当然 相同的数据类型 大小肯定是不变的 每次需要的时候不用都取 取一次之后当常数用就好了

02

第5讲 如何处理任意精度的数据类型

提起C/C++中本身的数据类型(native data types),我们会想到char、int、long等。这些数据类型对应的位宽是以8为边界的。相比于软件开发,FPGA设计中数据的位宽(也可称之为字长)是一个非常重要的因素。例如:一个输入数据均为18bit的乘法运算需要消耗1个DSP48,若输入数据位宽增至32bit,则需要消耗4个DSP48。可是C本身是无法声明一个18bit的数据。为此,Vivado HLS对数据类型做了扩展,设置了任意精度数据类型,以满足硬件设计的需求。更为重要的是,这种任意进度的数据类型继承了原有C数据类型所支持的操作,使得FPGA开发更为高效。此外,对于复合数据类型struct和enum,Vivado HLS也是支持的。

01

(转)java中equals和等号(==)的区别浅谈

java中的数据类型,可分为两类: 1.基本数据类型,也称原始数据类型。byte,short,char,int,long,float,double,boolean 他们之间的比较,应用双等号(==),比较的是他们的值。 2.复合数据类型(类) 当他们用(==)进行比较的时候,比较的是他们在内存中的存放地址,所以,除非是同一个new出来的对象,他们的比较后的结果为true,否则比较后结果为false。JAVA当中所有的类都是继承于Object这个基类的,在Object中的基类中定义了一个equals的方法,这个方法的初始行为是比较对象的内存地 址,但在一些类库当中这个方法被覆盖掉了,如String,Integer,Date在这些类当中equals有其自身的实现,而不再是比较类在堆内存中的存放地址了。 对于复合数据类型之间进行equals比较,在没有覆写equals方法的情况下,他们之间的比较还是基于他们在内存中的存放位置的地址值的,因为Object的equals方法也是用双等号(==)进行比较的,所以比较后的结果跟双等号(==)的结果相同。

02
领券