c语言 uint16_t,c中数据类型uint16_t,uint32_t,uint64_t输入输出使用方法

本文探讨了在编程中遇到的关于uint32_t类型定义的问题,指出了typedef的用法,并解释了为何在输入输出时可能需要使用I64u格式。重点讲解了如何正确输入和输出此类无符号整数类型及其在不同平台上的行为差异。
摘要由CSDN通过智能技术生成

前几天做题目,题目中要求数据类型使用uint32_t,大致一看,还以为就是int,但是在程序中把它当做int处理时出现了问题,为此在网上找了下资料

发现这个语句:

typedef unsigned __int32 uint32_t

其实就是无符号的32位int型数据。对于编程中出现的“uint32_t没有被定义”的错误,只需要将这行代码加载程序中就可以了

那么问题来了,对于这个类型的变量如何输入与输出呢。。。

下面给个例子(vc6.0)

#include

typedef unsigned __int16 uint16_t;

typedef unsigned __int32 uint32_t;

typedef unsigned __int64 uint64_t;

int main()

{

uint64_t num;

uint32_t num1;

uint16_t num2;

scanf("%I64u",&num);

scanf("%I32u",&num1);

scanf("%I16u",&num2);

printf("%I64u\n",num);

printf("%I64u\n",num1);

printf("%I64u\n",num2);

printf("%d\n",sizeof(num));

printf("%d\n",sizeof(num1));

printf("%d\n",sizeof(num2));

return 0;

}

可能会有疑问,为什么三个类型的数据在输出时都是一样的语句呢?其实我也有额。。。

你会发现自己把64换成32或者16后编译链接都可以,但是在运行时输出的是I32d,I16d,具体原因应该是编译器的问题,后来我用dev实验了下,发现I32d就可以输出,但是I16d还是不行。这个也可以不管,以后对于这些类型的数据都输出I64d就可以了,因为在输出时编译器会将uint32_t或者uint16_t变成uint64_t来输出,(类似于将char型数据使用%d输出)

总结:对于uint16_t,uint32_t,uint64_t的使用,在程序中加入typedef unsigned __int16 uint16_t;typedef unsigned __int32 uint32_t;typedef unsigned __int64 uint64_t;

输入语句:scanf("%I16u",&num);

输出语句:printf("%I64u",num);(u表示unsigned,有符号时使用d)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值