c++ 解決無法打印uint8_t 類型變量的問題
將uint8_t 轉化為unsigned 類型
使用一元運算符+(和- 運算符對應)
測試代碼如下
#include <cstdint>
#include <iostream>
#include <typeinfo>
int main()
{
std::uint8_t uint8_num = 10;
std::cout << "uint8_t num is " << uint8_num << std::endl; //無法打印
std::cout << "after cast to unsigned, uint8_t num is " << unsigned(uint8_num) << std::endl; //能正常打印
std::cout << "with a unary + operator, uint8_t num is " << +uint8_num << std::endl; //能正常打印
std::cout << "type of '+uint8_num' is " << typeid(+uint8_num).name() << std::endl;
return 0;
}
運行結果如下

可見使用+運算符的原理也是進行類型轉換(把uint8_t 轉為 int)
補充知識:C 語言printf打印各種數(shù)據(jù)類型的方法(u8/s8/u16/s16.../u64/double/float)(全)
首先必須知道u8,s8等數(shù)據(jù)類型的定義:
typedef signed char s8; typedef unsigned char u8; typedef signed short s16; typedef unsigned short u16; typedef signed int s32; typedef unsigned int u32; typedef signed long long s64; typedef unsigned long long u64;
與體系結構相關的,定義在include/linux/type.h文件中:
/* bsd */ 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;
對于各種數(shù)據(jù)類型的打印方式總結如下如下:
| 數(shù)據(jù)類型 | 打印格式 |
|---|---|
| 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:整數(shù)長度,y:小數(shù)點長度) |
待解問題,在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了。
以上這篇c++ 解決無法打印uint8_t 類型變量的問題就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
詳解Bucket Sort桶排序算法及C++代碼實現(xiàn)示例
桶排序是一種線性排序算法,這里我們來詳解Bucket Sort桶排序算法及C++代碼實現(xiàn)示例,需要的朋友可以參考下2016-07-07
C++實現(xiàn)單鏈表刪除倒數(shù)第k個節(jié)點的方法
這篇文章主要介紹了C++實現(xiàn)單鏈表刪除倒數(shù)第k個節(jié)點的方法,結合實例形式分析了C++單鏈表的定義、遍歷及刪除相關操作技巧,需要的朋友可以參考下2017-05-05

