type-cast的用法总结(一)
1、打开labview的后面板,通过programming——numeric——data manipulation,选择拖拽type cast模块,并将其进行最基础的线路连接。


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


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

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

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


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

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


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

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


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

声明:本网站引用、摘录或转载内容仅供网站访问者交流或参考,不代表本站立场,如存在版权或非法内容,请联系站长删除,联系邮箱:site.kefu@qq.com。
阅读量:159
阅读量:195
阅读量:49
阅读量:112
阅读量:25