linux下如何printf size_t/uint64_t

. linux下蛋疼的size_t/ssize_t

     32位环境下size_t被定义为unsigned int, 64位环境下size_t被定义为unsigned long, 对于一个需要同时运行在32位、64位环境的程序来说,在printf或者LOG size_t的时候会比较纠结,一般采用如下第12两种方式:

1. 强制类型转换

统一转换成unsigned long(或者其他类型):

printf("%lu", (unsigned long)size_t_var);

     写起来比较麻烦

2. 定义按环境适配的宏

#if __WORDSIZE == 64

#define SIZE_T_FMT "%lu"

#else

#define SIZE_T_FMT "%u"

#endif

          printf(SIZE_T_FMT, size_t_var);

         写起来还是麻烦

3. 终极方式

实际上,针对size_t类型是有标准的格式串的,不过这里有2个标准格式串:

       a)       Posix%zu(小写的z)

       b)       Gnu%Zu(大写的Z)

       printf(“%zu”, size_t_var); 或者printf(“%Zu”, size_t_var);

      写起来非常简单

      size_tunsigned类型,对应的signed类型是ssize_tssize_t的格式串是%zd或者%Zd

备注:

        man 3 printf的时候,有如下一条说明:

        z      A following integer conversion corresponds to a size_t or ssize_t argument. (Linux libc5 has Z with thismeaning. Don't use it.)

       看起来像是推荐使用大写版本的%Zu/%Zd,不过测试表明大小写版本都能正常工作,保险起见尽量使用大写版本。

. linux下蛋疼的uint64_t/int64_t

         32位环境下uint64_t被定义为unsignedlong long, 64位环境下uint64_t被定义为unsigned long, 纠结原因同上面的size_t。传统方式依旧为:1.printf前先强转,2.定义根据环境适配的FMT宏。

         不过没有size_t那么幸运,并没有直接针对uint64_t的统一格式串,但是经过一番挖掘后发现,stdint.h有一种类型定义为uintmax_t,跟uint64_t完全等价,而uintmax_t有统一的格式串:%ju。所以在printf/LOG uint64_t时,可以很自然的将%ju用于其中:

              printf(“%ju”, uint64_t_var);

              uint64_tunsigned类型,对应的signed类型是int64_tint64_t的格式串是%jd

  • 6
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
以下是一个简单的Linux C语言实现Base64加密的示例代码: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> static const char base64_chars[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; char *base64_encode(const unsigned char *data, size_t input_length, size_t *output_length) { *output_length = 4 * ((input_length + 2) / 3); char *encoded_data = malloc(*output_length + 1); if (encoded_data == NULL) return NULL; for (size_t i = 0, j = 0; i < input_length;) { uint32_t octet_a = i < input_length ? (unsigned char)data[i++] : 0; uint32_t octet_b = i < input_length ? (unsigned char)data[i++] : 0; uint32_t octet_c = i < input_length ? (unsigned char)data[i++] : 0; uint32_t triple = (octet_a << 0x10) + (octet_b << 0x08) + octet_c; encoded_data[j++] = base64_chars[(triple >> 3 * 6) & 0x3F]; encoded_data[j++] = base64_chars[(triple >> 2 * 6) & 0x3F]; encoded_data[j++] = base64_chars[(triple >> 1 * 6) & 0x3F]; encoded_data[j++] = base64_chars[(triple >> 0 * 6) & 0x3F]; } for (size_t i = 0; i < (*output_length % 4); i++) { encoded_data[*output_length - 1 - i] = '='; } return encoded_data; } int main(int argc, char *argv[]) { const char *input_str = "hello, world!"; size_t input_len = strlen(input_str); size_t output_len = 0; char *encoded_str = base64_encode((const unsigned char *)input_str, input_len, &output_len); printf("Encoded string: %s\n", encoded_str); free(encoded_str); return 0; } ``` 这个示例代码使用了一个包含64个字符的字符表(base64_chars),以及一个base64_encode函数,该函数将输入的数据编码成Base64格式,并返回编码后的字符串。在main函数中,我们首先声明一个字符串,然后计算它的长度,并将其传递给base64_encode函数。该函数将返回一个指向编码后的字符串的指针,我们可以将其打印出来。最后,我们释放了分配给编码字符串的内存。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值