博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
uint8_t / uint16_t / uint32_t /uint64_t 的简单介绍
阅读量:6001 次
发布时间:2019-06-20

本文共 2936 字,大约阅读时间需要 9 分钟。

在nesc的代码中,你会看到很多你不认识的数据类型,比如uint8_t等。咋一看,好像是个新的数据类型,不过C语言(nesc是C的扩展)里面好像没有这种数据类型啊!怎么又是u又是_t的?很多人有这样的疑问。论坛上就有人问:以*_t结尾的类型是不是都是long型的?在baidu上查一下,才找到答案,这时才发觉原来自己对C掌握的太少。

那么_t的意思到底表示什么?具体的官方答案没有找到,不过我觉得有个答案比较接近。它就是一个结构的标注,可以理解为type/typedef的缩写,表示它是通过typedef定义的,而不是其它数据类型。

uint8_t,uint16_t,uint32_t等都不是什么新的数据类型,它们只是使用typedef给类型起的别名,新瓶装老酒的把戏。不过,不要小看了typedef,它对于你代码的维护会有很好的作用。比如C中没有bool,于是在一个软件中,一些程序员使用int,一些程序员使用short,会比较混乱,最好就是用一个typedef来定义,如: typedef char bool;

一般来说,一个C的工程中一定要做一些这方面的工作,因为你会涉及到跨平台,不同的平台会有不同的字长,所以利用预编译和typedef可以让你最有效的维护你的代码。为了用户的方便,C99标准的C语言硬件为我们定义了这些类型,我们放心使用就可以了。

按照posix标准,一般整形对应的*_t类型为: 1字节     uint8_t 2字节     uint16_t 4字节     uint32_t 8字节     uint64_t

附:C99标准中inttypes.h的内容 00001 /* 00002    inttypes.h 00003 00004    Contributors: 00005      Createdby Marek Michalkiewicz <marekm@linux.org.pl> 00006 00007    THISSOFTWARE IS NOT COPYRIGHTED 00008 00009    Thissource code is offered for use in the public domain.  You may 00010    use,modify or distribute it freely. 00011 00012    Thiscode is distributed in the hope that it will be useful, but 00013    WITHOUTANY WARRANTY.  ALLWARRANTIES, EXPRESS OR IMPLIED ARE HEREBY 00014    DISCLAIMED.  This includes but is not limited towarranties of 00015    MERCHANTABILITYor FITNESS FOR A PARTICULAR PURPOSE. 00016  */ 00017 00018 #ifndef __INTTYPES_H_ 00019 #define __INTTYPES_H_ 00020 00021 /* Use [u]intN_t if you need exactly N bits. 00022    XXX- doesn't handle the -mint8 option.  */ 00023 typedefsigned char int8_t; typedefunsigned char uint8_t; 00026 typedefint int16_t; typedefunsigned int uint16_t; 00029 typedeflong int32_t; typedefunsigned long uint32_t; 00032 typedeflong long int64_t; typedefunsigned long long uint64_t; 00035 typedefint16_t intptr_t; typedefuint16_t uintptr_t; 00038 00039 #endif

------------

1>. 在写程序时注意"无符号类型"的使用, 各种类型边界值的情况.

如:
a>
当某个数据不可能为负数时我们一定要考虑用以下类型:
unsigned char,
unsigned int, uint32_t, size_t, uint64_t, unsigned long
int,
b> 当有些数据你不知道是正负时一定不要用"a>"中的类型,
不然他永远也不可能为负.
c> 数据的边界值要多注意, 如:
uint32_t a, b, c;
uint64_t
m;
m = a * b + c;
在该运算中可能出现错误,
"a*b"的类型可能超过uint32_t的最大值,这时一定不要忘了类型转换.
m
= ((uint64_t)a) * b + c;
2>. 在适当的时候要会自我定义数据类型.
我们都知道linux C开发中的常见扩展数据类型的定义有:uint8_t, uint16_t, uint32_t, uint64_t, size_t,
ssize_t, off_t .... 他之所以要自己定义出数据类型是有道理的, 如: typdef unsigned int uint32_t;
表示uint32_t为32位无符号类型数据, 其实size_t也是32位无符号数据类型, 为什么不直接写"unsigned int"呢?
为了程序的可扩展性, 假如将来我们需要的数据大小变成了64bit时,我们只需要将typedef long long size_t就可以了,
不然我们可要修改好多好多的地方了.
这种设计我们同样可以应用到自己的开发中来,当自己设计一个int类型保存某种数据时,但你又没把握将来是不是要用long
int时你可以引用一个自己定义的数据类型的啊!
stdint.h
-----------------------------
typedef
unsigned int
uint32_t;
uint32_t.c
-----------------------------
#include
<stdio.h>
#if 0
#include
<stdint.h> //
uint32_t
#endif
typedef
unsigned int uint32_t;
typedef
unsigned long long
uint64_t;
int
main()
{
uint32_t
a;
a =
12;
printf("a = %x\n",
a);
printf("sizeof(a) = %d\n",
sizeof(a));
uint64_t
b;
b =
12;
printf("b = %x\n",
b);
printf("sizeof(b) = %d\n",
sizeof(b));
}
a = c
sizeof(a) = 4
b =
c
sizeof(b) = 8

 

转载地址:http://owdmx.baihongyu.com/

你可能感兴趣的文章
Node.js 抓取电影天堂新上电影节目单及ftp链接
查看>>
js课程 3-9 js内置对象定时器和超时器怎么使用
查看>>
linux popen函数
查看>>
[游戏开发]关于手游客户端网络带宽压力的一点思考
查看>>
如何成为强大的程序员?
查看>>
How To: 用 SharePoint 计算列做出你自己的KPI列表
查看>>
Visual Studio下使用jQuery的10个技巧
查看>>
web服务器工作原理及http协议通信
查看>>
数据库查询某个字段值的位数 语法
查看>>
java file 文件操作 operate file of java
查看>>
WPF获取路径解读
查看>>
【实战HTML5与CSS3】用HTML5和CSS3制作页面(上)
查看>>
Android : 如何在WebView显示的页面中查找内容
查看>>
数字信号处理 基础知识 对比回顾
查看>>
分享个人Vim型材
查看>>
配置算法(第4版)的Java编译环境
查看>>
本学习笔记TCP/IP传输协议
查看>>
配置 Windows 下的 nodejs C++ 模块编译环境 安装 node-gyp
查看>>
201215-03-19---cocos2dx内存管理--具体解释
查看>>
swift菜鸟入门视频教程-12-21讲
查看>>