C语言中vu16什么意思,15.stm32 数据类型的定义(常用的U8,U16,U32到底代表什么)

满意答案

dcebd7a0de6265b6ccae5ead692f1eab.png

月冰p莹月

2020.09.14

dcebd7a0de6265b6ccae5ead692f1eab.png

采纳率:48%    等级:12

已帮助:9104人

去百度文库,查看完整内容>

内容来自用户:尘客i 在KeilMDK开发环境里,比如一个无符号32位整形数据会有很多种表示方法:

1,unsignedint32(C语言标准表达方法)

2,uint32_t;

3,u32;

这三种方式都是在表达同一个意思,可为什么ST的开发人员要搞的这么乱呢?

还有其他好多你可能看起来很陌生,很不好理解的表达方式,

如:_IOint32_t他等同于vs32(这个你同样很陌生),不过他还等同于volatileint32_t,还等同于volatilesignedint32;

最后这种表达方式才是C语言的标准表达方式,够乱吧,能把初学者弄的晕头转向。

u8,u16,u32都是unsignedchar类型,不过u8是一个字节的,u16是2字节,u32是4字节typed.

u8是unsignedchar

u16是unsignedshort

u32是unsignedint

u8最大255u16最大65535就这个意思u8a=255a+1=0u16b=255b+1=256

其实ST搞这么多花样,无非是想开发人员在写代码时定义数据类型能少写几个符号,然后又因为前后版本升级,为了兼容旧版本(主要是V2.0)才会出现这么多表示方法。不管他怎么换,都是基于标准C来的,看清楚以下几个文件你就OK了:

core_cm3.h;stm32f10x.h;stdint.h;其中每个文件大概作用如下:

stdint.h这里放着C语言的标准表达方式

//第36行开始

typedefsignedcharint8_t;//标准表达方式signedchar被等同于int8_t;

typedefsignedshortintint16_t;

typedefsignedintint32_t;//在32位环境里,i

00分享举报

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值