1 C基本数据类型

C基本的数据类型说明:

2 字节序

测试代码:

#include <stdio.h>

typedef unsigned char *byte_pointer;

void show_bytes(byte_pointer start, int len)
{
int i; for (i = 0; i < len; i++) {
printf(" %.2x", start[i]);
}
printf("\n");
} int main(void)
{
int x = 0x01234567; show_bytes((byte_pointer)&x, sizeof(x)); return 0;
}

编译运行测试:

$ gcc endian.c
$ ./a.out
67 45 23 01

可以看出,当前我运行的机器是小端序。

3 结构体

参考:C语言技术天花板【结构体】一节课掌握_哔哩哔哩_bilibili

结构体中成员排列的规则:

  1. 结构体成员的内部偏移量(内部地址),要被这个成员的数据类型的大小整除。

    struct test {
    int a; /* [Byte][Byte][Byte][Byte] */
    char c; /* [Byte][0x00] */
    short s; /* [Byte][Byte] */
    };
    /* 结构体的内存大小 */
    sizeof(struct test) = 8; /* 结构体中的内存分布,可看出成员c后面填充了1Byte的0x00 */
    struct test test1 = {0};
    test1.a = 0x12345678;
    test1.c = 0xbb;
    test1.s = 0xccdd; (gdb) x /8bx &test1
    0x7fffffffe110: 0x78 0x56 0x34 0x12 0xbb 0x00 0xdd 0xcc
  2. 整个结构体的大小,必须是最大成员的size的整数倍,否则就需要在末尾填充空白字节。

    struct test {
    int a; /* [Byte][Byte][Byte][Byte] */
    char c; /* [Byte] */
    };
    /* 结构体的内存大小 */
    sizeof(struct test) = 8; /* 结构体中的内存分布,可看出成员c后面填充了3Byte的0x00 */
    (gdb) x /8bx &test1
    0x7fffffffe110: 0x78 0x56 0x34 0x12 0xbb 0x00 0x00 0x00
  3. 对于结构体中的结构体,按照结构体展开之后的内存对齐来处理。

    struct test1 {
    int a; /* [Byte][Byte][Byte][Byte] */
    short s; /* [Byte][Byte][0x00][0x00] */
    }; struct test {
    int a; /* [Byte][Byte][Byte][Byte] */
    char c; /* [Byte][0x00][0x00][0x00]*/
    struct test1 s;
    };
    /* 结构体的内存大小为16,根据规则1,成员c后面补充3Bytes的0x0,根据规则2,s.s成员后面补充2Bytes的0x0 */
    sizeof(struct test) = 16; /* 结构体中的内存分布 */
    struct test test1 = {0};
    test1.a = 0x12345678;
    test1.c = 0xff;
    test1.s.a = 0xaabbccdd;
    test1.s.s = 0x9988;
    (gdb) x /16bx &test1
    0x7fffffffe100: 0x78 0x56 0x34 0x12 0xff 0x00 0x00 0x00
    0x7fffffffe108: 0xdd 0xcc 0xbb 0xaa 0x88 0x99 0x00 0x00
  4. 认为指定特殊的对齐规则,使用#pragma pack(n)指定每个成员的其实地址,按照n来对齐,覆盖第一条规则。如果整个n比第一条规则对齐还要大,那么就取小的。

    #pragma pack(2)
    struct test1 {
    int a; /* [Byte][Byte][Byte][Byte] */
    short s; /* [Byte][Byte] */
    }; struct test {
    int a; /* [Byte][Byte][Byte][Byte] */
    char c; /* [Byte][0x00] */
    struct test1 s;
    };
    /* 结构体的内存大小为12,根据规则4,成员c后面补充1Bytes的0x0 */
    sizeof(struct test) = 12; /* 结构体中的内存分布 */
    struct test test1 = {0};
    test1.a = 0x12345678;
    test1.c = 0xff;
    test1.s.a = 0xaabbccdd;
    test1.s.s = 0x9988;
    (gdb) x /12bx &test1
    0x7fffffffe110: 0x78 0x56 0x34 0x12 0xff 0x00 0xdd 0xcc
    0x7fffffffe118: 0xbb 0xaa 0x88 0x99
    #pragma pack(8)
    struct test1 {
    int a; /* [Byte][Byte][Byte][Byte] */
    short s; /* [Byte][Byte] */
    }; struct test {
    int a; /* [Byte][Byte][Byte][Byte] */
    char c; /* [Byte][0x00] */
    struct test1 s;
    }; /* 规则1生效 */
    sizeof(struct test) = 16;
  5. 不使用任何对齐,直接存放数据的方式,使用#pragma pack(1)

    #pragma pack(1)
    struct test1 {
    int a; /* [Byte][Byte][Byte][Byte] */
    short s; /* [Byte][Byte] */
    }; struct test {
    int a; /* [Byte][Byte][Byte][Byte] */
    char c; /* [Byte] */
    struct test1 s;
    };
    /* 结构体的内存大小为11,各个成员之间不会填充0x0 */
    sizeof(struct test) = 11; /* 结构体中的内存分布 */
    struct test test1 = {0};
    test1.a = 0x12345678;
    test1.c = 0xff;
    test1.s.a = 0xaabbccdd;
    test1.s.s = 0x9988;
    (gdb) x /11bx &test1
    0x7fffffffe110: 0x78 0x56 0x34 0x12 0xff 0xdd 0xcc 0xbb
    0x7fffffffe118: 0xaa 0x88 0x99

C基本知识的更多相关文章

  1. 你必须知道的EF知识和经验

    注意:以下内容如果没有特别申明,默认使用的EF6.0版本,code first模式. 推荐MiniProfiler插件 工欲善其事,必先利其器. 我们使用EF和在很大程度提高了开发速度,不过随之带来的 ...

  2. MySQL高级知识- MySQL的架构介绍

    [TOC] 1.MySQL 简介 概述 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,目前属于Oracle公司. MySQL是一种关联数据库管理系统,将数据保存在不同的表中,而 ...

  3. 学点HTTP知识

    不学无术 又一次感觉到不学无术,被人一问Http知识尽然一点也没答上来,丢人丢到家了啊.平时也看许多的技术文章,为什么到了关键时刻就答不上来呢? 确实发现一个问题,光看是没有用的,需要实践.看别人说的 ...

  4. java中的字符串相关知识整理

    字符串为什么这么重要 写了多年java的开发应该对String不陌生,但是我却越发觉得它陌生.每学一门编程语言就会与字符串这个关键词打不少交道.看来它真的很重要. 字符串就是一系列的字符组合的串,如果 ...

  5. [C#] C# 知识回顾 - 你真的懂异常(Exception)吗?

    你真的懂异常(Exception)吗? 目录 异常介绍 异常的特点 怎样使用异常 处理异常的 try-catch-finally 捕获异常的 Catch 块 释放资源的 Finally 块 一.异常介 ...

  6. [C#] C# 知识回顾 - 学会处理异常

    学会处理异常 你可以使用 try 块来对你觉得可能会出现异常的代码进行分区. 其中,与之关联的 catch 块可用于处理任何异常情况. 一个包含代码的 finally 块,无论 try 块中是否在运行 ...

  7. [C#] C# 知识回顾 - 学会使用异常

    学会使用异常 在 C# 中,程序中在运行时出现的错误,会不断在程序中进行传播,这种机制称为“异常”. 异常通常由错误的代码引发,并由能够更正错误的代码进行 catch. 异常可由 .NET 的 CLR ...

  8. [C#] C# 知识回顾 - 异常介绍

    异常介绍 我们平时在写程序时,无意中(或技术不够),而导致程序运行时出现意外(或异常),对于这个问题, C# 有专门的异常处理程序. 异常处理所涉及到的关键字有 try.catch 和 finally ...

  9. [.NET] C# 知识回顾 - Event 事件

    C# 知识回顾 - Event 事件 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/6060297.html 序 昨天,通过<C# 知识回顾 - ...

  10. [.NET] C# 知识回顾 - 事件入门

    C# 知识回顾 - 事件入门 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/6057301.html 序 之前通过<C# 知识回顾 - 委托 de ...

随机推荐

  1. JavaScript中数值小知识

    1. 数值10.0 这种类似的会被去掉数值后的0 之所以这样是因为,整数的存储空间占用比浮点数小,当一个数值不是真浮点数(即10.0这种格式),会被转换为整数10,如果业务中有一些需求需要进行数值位数 ...

  2. 力扣609(java&python)-在系统中查找重复文件(中等)

    给你一个目录信息列表 paths ,包括目录路径,以及该目录中的所有文件及其内容,请你按路径返回文件系统中的所有重复文件.答案可按 任意顺序 返回. 一组重复的文件至少包括 两个 具有完全相同内容的文 ...

  3. 力扣535(java)-TinyURL的加密与解密(中等)

    题目: TinyURL 是一种 URL 简化服务, 比如:当你输入一个 URL https://leetcode.com/problems/design-tinyurl 时,它将返回一个简化的URL  ...

  4. 力扣227(java)-基本计算器Ⅱ(中等)

    题目: 给你一个字符串表达式 s ,请你实现一个基本计算器来计算并返回它的值. 整数除法仅保留整数部分. 你可以假设给定的表达式总是有效的.所有中间结果将在 [-231, 231 - 1] 的范围内. ...

  5. 云原生微服务的下一站,微服务引擎 MSE 重磅升级

    ​简介:管好微服务,成为云原生时代的新难题. 管好微服务,成为云原生时代的新难题. 从建好微服务到管好微服务,差的虽是一个字,连接起两边的却需要大量的微服务落地经验.因为软件架构的核心挑战是解决业务快 ...

  6. 1小时打造HaaS版小小蛮驴智能车

    简介: 2020年云栖大会上,阿里云发布了一款机器人"小蛮驴",瞬间激起千层浪,无人车,智能物流,机器人等一些概念又火热了一把. 借"小蛮驴"的东风以及火热的H ...

  7. 慢SQL治理分享

    简介: 这里的慢SQL指的是MySQL慢查询,是运行时间超过long_query_time值的SQL.真实的慢SQL通常会伴随着大量的行扫描.临时文件排序或者频繁的磁盘flush,直接影响就是磁盘IO ...

  8. [PHP] Laravel auth:airlock 更名 auth:sanctum

    本以为有了一种改善型的服务出来了,没想到不是. 关于 Laravel 现有的三大验证方式看这里:[PHP] 浅谈 Laravel 三大验证方式的区别, auth:api, passport, auth ...

  9. dotnet 读 WPF 源代码笔记 简单聊聊文本布局换行逻辑

    在 WPF 里面,带了基础的文本库功能,如 TextBlock 等.文本库排版的重点是在文本的分行逻辑,也就是换行逻辑,如何计算当前的文本字符串到达哪个字符就需要换到下一行的逻辑就是文本布局的重点模块 ...

  10. 2019-11-29-dotnet-remoting-使用事件

    title author date CreateTime categories dotnet remoting 使用事件 lindexi 2019-11-29 10:20:1 +0800 2018-2 ...