type-cast的用法总结(一)
来源:网络收集 点击: 时间:2024-07-09打开labview的后面板,通过programming——numeric——data manipulation,选择拖拽type cast模块,并将其进行最基础的线路连接。


我们将输入类型选择为I16(含16bits);
而type类型为:U8(含8bits);


此时我们发现输入的32767,输出的确实127。数值变小,这至少说明在转换中数据出现了溢出。

之所以出现溢出,是因为将16位数据转换为8位数据时失去了8位的数值,而在labview cast定义中,失去的是低权位的数值,所以这里只保留了16位数值的左侧8位。我们经过下面的计算就可以知道结果却是127;
注:对于正整数,有符号和无符号二进制数值转换为10进制时结果一模一样。

如果将type变为I16和U16,根据上一步的注,可以知道此事位宽均相同。


此时位宽完全相同,数值完全等于输入的数值。此时相当于没有进行任何数值转换。

有前面知道,输入为I16;
如果我们将type变为I32;此时位宽增加了16位;
运行后可以看到数值远远大于输入数值。


此时转换过程是,I16位从I32位的左侧开始占空,而右侧的低权位缺省位、为0;
注1:输入为有符号,符号位为0;
注2:转换为无符号时,守卫仍为0;
注3:位宽的位置序号从右往左,从0开始计数。

同样,当我们将type类型改为I64位,此时位宽进一步加倍;
计算结果更加接近天文数字,和输入值之间的关系很难捉摸。


此时我们只需要知道右侧缺省0的位数为48,然后很方便进行算数计算就可以得到labview一样的结果。
注:符号位为正,用0赋值。

欢迎交流和投票
请尊重知识产权
TYPECAST强制转换LABVIEW位宽版权声明:
1、本文系转载,版权归原作者所有,旨在传递信息,不代表看本站的观点和立场。
2、本站仅提供信息发布平台,不承担相关法律责任。
3、若侵犯您的版权或隐私,请联系本站管理员删除。
4、文章链接:http://www.1haoku.cn/art_945282.html