×

DSP编程技巧中数据类型的全解析

消耗积分:0 | 格式:rar | 大小:0.1 MB | 2017-10-17

分享资料个

  DSP的C/C++编程时有多少种数据类型?float,double和long double,long和long long这些绕口的名字究竟有什么区别?数据类型使用不正确又会有什么后果?如果你感觉说不清楚,那我们来看看这些到底都是何方神圣吧:

  64位整数的处理

  从上面的表中,可以看出C28x的编译器是支持64位的整数类型的,这使得在处理某些高精度智能编码器的反馈数据时特别方便,因为在更老的不支持64位整数类型的器件上编程时,需要我们自己定义64位类型,在运算时要自己定义运算规则才行。一个long long类型的整数需要使用ll或者LL前缀,才能被I/O正确处理,例如,我们使用下面的代码才能正确把它们显示在屏幕上:

  printf(“%lld”, 0x0011223344556677);

  printf(“%llx”, 0x0011223344556677);

  需要注意的是,虽然编译器支持了64位整数,但是实际的CPU的累加器还有相关的CPU寄存器还是32位的,在程序运行时,64位整数类型是被CPU“软支持”的。我们可以添加相关的实时运行库来提高效率,其中包含了llabs(), strtoll() 和strtoull()等函数。

  DSP编程技巧中数据类型的全解析

  表1 C28x C/C++支持的数据类型

  浮点的处理

  从表1中我们可以看出,C28x的编译器支持32位的单精度浮点、64位的单精度和双精度浮点运算。在定义双精度64位变量时,也要记得使用l或者L前缀,否则会被视为双精度的32位变量,造成精度的损失。例如:

  long double a = 12.34L; 初始化为双精度64位浮点

  long double b = 56.78; 把单精度浮点强制类型转换为双精度浮点

  在I/O处理时,也要标有相关的前缀,例如:

  printf(“%Lg”, 1.23L);

  printf(“%Le”, 3.45L);

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

评论(0)
发评论

下载排行榜

全部0条评论

快来发表一下你的评论吧 !