(持续更新中!!~)19、原来可以这样理解C语言_自定义类型:结构体(1/8) 结构体类型的声明

目录

 1. 结构体类型的声明

1.1 结构体回顾

1.1.1 结构的声明

1.1.2 结构体变量的创建和初始化

1.2 结构的特殊声明

1.3 结构的⾃引⽤


 1. 结构体类型的声明

前⾯我们在学习操作符的时候,已经学习了结构体的知识,这⾥稍微复习⼀下。

1.1 结构体回顾

结构是⼀些值的集合,这些值称为成员变量。结构的每个成员可以是不同类型的变量。

1.1.1 结构的声明
struct tag

{
 member-list;
}variable-list;

例如描述⼀个学⽣:

struct Stu

{
     char name[20];//名字 
     int age;//年龄 
     char sex[5];//性别 
     char id[20];//学号 
}; //分号不能丢 
1.1.2 结构体变量的创建和初始化
#include <stdio.h>

struct Stu

{
 char name[20];//名字 
 int age;//年龄 
 char sex[5];//性别 
 char id[20];//学号 
};

int main()
{
 //按照结构体成员的顺序初始化 
 struct Stu s = { "张三", 20, "男", "20230818001" };
 printf("name: %s\n", s.name);
 printf("age : %d\n", s.age);
 printf("sex : %s\n", s.sex);
 printf("id : %s\n", s.id);
 
 //按照指定的顺序初始化 
 struct Stu s2 = { .age = 18, .name = "lisi", .id = "20230818002", .sex = 

"⼥" };
 printf("name: %s\n", s2.name);
 printf("age : %d\n", s2.age);
 printf("sex : %s\n", s2.sex);
 printf("id : %s\n", s2.id);
 return 0;
}

1.2 结构的特殊声明

在声明结构的时候,可以不完全的声明。

⽐如:

//匿名结构体类型 

struct
{
 int a;
 char b;
 float c;
}x;

 struct
{
 int a;
 char b;
 float c;
}a[20], *p;

上⾯的两个结构在声明的时候省略掉了结构体标签(tag)。

 那么问题来了?

//在上⾯代码的基础上,下⾯的代码合法吗?

p = &x;

警告:

        编译器会把上⾯的两个声明当成完全不同的两个类型,所以是⾮法的。

         匿名的结构体类型,如果没有对结构体类型重命名的话,基本上只能使⽤⼀次。

1.3 结构的⾃引⽤

在结构中包含⼀个类型为该结构本⾝的成员是否可以呢?

⽐如,定义⼀个链表的节点:

struct Node

{
     int data;
     struct Node next;
};

        上述代码正确吗?如果正确,那 sizeof(struct Node) 是多少?

         仔细分析,其实是不⾏的,因为⼀个结构体中再包含⼀个同类型的结构体变量,这样结构体变量的⼤ ⼩就会⽆穷的⼤,是不合理的。

        正确的⾃引⽤⽅式:

struct Node
{
 int data;
 struct Node* next;
};

        在结构体⾃引⽤使⽤的过程中,夹杂了 typedef 对匿名结构体类型重命名,也容易引⼊问题,看看 下⾯的代码,可⾏吗?

typedef struct

{
     int data;
     Node* next;
}Node;

        答案是不⾏的,因为Node是对前⾯的匿名结构体类型的重命名产⽣的,但是在匿名结构体内部提前使 ⽤Node类型来创建成员变量,这是不⾏的。

         解决⽅案如下:定义结构体不要使⽤匿名结构体了

typedef struct Node

{
     int data;
     struct Node* next;
}Node;

内容概要:本文详细记录了对一个Android ARM64静态ELF文件中字符串加密机制的逆向分析过程。该ELF文件的所有字符串均被加密,无法通过常规strings命令或IDA直接识别。作者通过分析发现,加密字符串存储在.rodata段,其解密所需信息(包括密文地址、长度和16位密钥)保存在.data.rel.ro段的40字节描述符中。核心解密函数sub_10F408采用自反的双pass流密码算法,结合固定密钥KEY_TERM(由.data段24字节数据计算得出),实现字节级非线性、位置与长度相关的加密。文章还复现了完整的Python解密脚本,并揭示了该保护机制的本质为代码混淆而非强加密,最终成功批量解密全部956条字符串,暴露程序真实行为,如shell命令模板、设备标识篡改、网络重置等操作。此外,文中还提及未启用的自定义壳框架及其反dump设计。; 适合人群:具备逆向工程基础的安全研究人员、二进制分析人员及对ELF保护技术感兴趣的开发者。; 使用场景及目标:①学习ELF二进制中字符串加密的典型实现方式与逆向突破口;②掌握从结构识别、函数追踪到算法还原的完整逆向流程;③理解“绑定二进制”的完整性校验设计及其局限性;④实践编写IDAPython脚本自动化提取与解密敏感数据。; 阅读建议:此资源以实战案例驱动,不仅展示技术细节,更强调逆向思维与验证方法,建议读者结合IDA调试环境,逐步跟随文中步骤进行动态分析与算法验证,深入理解每一步的推理依据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值