typedef unsigned char u_char;
typedef unsigned short u_short;
typedef unsigned int u_int;
typedef unsigned long u_long;
/* sysv */
typedef unsigned char unchar;
typedef unsigned short ushort;
typedef unsigned int uint;
typedef unsigned long ulong;
#ifndef __BIT_TYPES_DEFINED__
#define __BIT_TYPES_DEFINED__
typedef __u8 u_int8_t;
typedef __s8 int8_t;
typedef __u16 u_int16_t;
typedef __s16 int16_t;
typedef __u32 u_int32_t;
typedef __s32 int32_t;
#endif /* !(__BIT_TYPES_DEFINED__) */
typedef __u8 uint8_t;
typedef __u16 uint16_t;
typedef __u32 uint32_t;
#if defined(__GNUC__)
typedef __u64 uint64_t;
typedef __u64 u_int64_t;
typedef __s64 int64_t;
对于各种数据类型的打印方式总结如下如下:
数据类型
|
打印格式
|
u8
|
%d
|
s8
|
%d
|
u16
|
%d or %hu
|
s16
|
%d or %hd
|
u32
|
%u
|
s32
|
%d
|
u64
|
%llu
|
s64
|
%lld
|
int
|
%d
|
unsigned int
|
%u
|
short int
|
%d or %hd
|
long
|
%ld
|
unsigned long
|
%lu
|
long long
|
%lld
|
unsigned long long
|
%llu
|
char
|
%c
|
char *
|
%s
|
bool (#define stdbool.h)
|
%d
|
unsigned int/int------>十六进制
|
%0x
|
unsigned long/long---->十六进制
|
%0lx
|
long long/unsigned long long ----->十六进制
|
%0llx
|
unsigned int/int------>八进制
|
%0o
|
unsigned long/long---->八进制
|
%0lo
|
long long/unsigned long long ----->八进制
|
%0llo
|
float
|
%f
|
double
|
%f or %lf
|
科学技术类型(必须转化为double类型)
|
%e
|
限制输出字段宽度
|
%x.yf (x:整数长度,y:小数点长度)
|
待解问题,在linux kernel里面也有使用bool来定义变量,查看code,定义如下:
typedef _Bool bool;
但是并没有真正找到具体定义在何处,待解。下面是stdbool.h的source code:
#define _STDBOOL_H
#ifndef __cplusplus
#define bool _Bool
#define true 1
#define false 0
#else /* __cplusplus */
/* Supporting _Bool in C++ is a GCC extension. */
#define _Bool bool
#if __cplusplus < 201103L
/* Defining these macros in C++98 is a GCC extension. */
#define bool bool
#define false false
#define true true
#endif
#endif /* __cplusplus */
/* Signal that all the definitions are present. */
#define __bool_true_false_are_defined 1
#endif /* stdbool.h */
也大致解释了linux kernel bool type了。
如果大家有兴趣,可以扫码关注我的个人公众号:
/*!< Signed integer types */
typedef signed char int8_t;
typedef signed short int16_t;
typedef signed long int32_t;
/*!< Unsigned integer...
本篇文章我们来学习如何在C++中打印数据,在C语言中我们会使用hello world来打印数据,那么在C++中是如何实现数据的打印呢?本篇文章就讲解到这里,希望大家好好理解并做实验尝试。
C语言是一种强类型语言,也就是说,C语言的变量使用要严格符合定义,所有变量都必须先定义后使用。另外,printf必须使用对应的转换说明符才能打印对应的数据类型数据,下面我们整体了解一下。有符号整型有符号整型可以用来定义正整数和负整数,有下面几种类型:int:最常使用的类型,是系统的基本类型,C语言标准规定,int类型至少16位长。printf中使用%d进行打印。short或short int:C语...
需要注意的是,在如何使用占位符时,要确保占位符和对应数据类型相匹配。如果占位符与数据类型不匹配,将会出现意想不到的结果,并且可能会导致程序崩溃或者产生错误的输出。另外,C语言还提供了一些格式控制字,例如%e、%E、%g、%G等,这些格式控制字可以用来控制浮点数的输出格式。关于这些格式控制字的使用可以查看C语言的相关资料。puts函数在输出字符串时,会自动添加换行符。需要注意的是,在输出时,可以使用多个占位符。
C语言 格式化输出与变量类型 1、格式化输出在PHP里面,我们一般都是用echo和var_dump以及print_r等来输出调试语句,在C语言中一般用printf来输出,不过由有...
要打印unsigned int 数字,可以使用%u符号。打印long数值,可以使用%d 格式说明符。如果系统的 int 和 long 类型具有同样的长度,使用%d 就可以打印 long 数值,但是这会给程序移植到其他系统(这两种数据类型的长度不一样的系统)带来麻烦,所以建议使用 %ld打印 long 数值。在x和o符号前也可以使用l前缀,因此 %lx表示以十六进制格式打印长整数,%lo
蓝桥杯单片机 赛后资料整理(三)——IIC总线通用操作写操作顺序读操作随机读操作代码模板FCP8591读电位器和光敏电阻输出电压AT24C02
本文适用于CT107D竞赛板+IAP15转接板
资料中提供了相对完整的IIC的库函数,所以,可以不用深入的了解IIC总线的时钟顺序。而以下是选手必须要了解的。
器件地址: 地址的前4位由器件的型号决定,FCP8591
顺序读操作
随机...
想必大家都知道printf打印int 型是用%d,但是u8,u16,u32,u64还有s8,s16,s32,s64是如何打印呢,知道的大佬绕行哈,不知道往下看看。
what is u8?
常见的u8其实是自定义的,定义如下:
typedef signed char s8;
typedef unsigned char u8;
typedef signed short s16;
typedef unsigned short u16;
typedef signed int s32;