Class文件结构介绍[字段表集合和方法表集合]

private int age = 18;

在这里插入图片描述

字段表中包含固定数据项目到descriptor_index为止就结束了,不过在此之后跟随着一个属性表集合用于存储一些额外信息,字段都可以在属性表中描述零至多个额外信息,在上面的三个字段中name为静态常量所以属性表中有信息,如下

在这里插入图片描述

具体的属性表下篇文章具体介绍。

方法表集合

===================================================================

方法表和字段表很相似,如果字段表弄清楚了那么方法表也很简单,先来看下classpy观察的样例结果:

public final class Test2 {

private static final String NAME=“bobo”;

private String users[][];

private int age = 18;

public void fun1(){

int b = 20;

int c = 30;

int d = b+c+age;

System.out.println(d);

}

}

在这里插入图片描述

方法表的结构

在这里插入图片描述

| 名称 | 类型 | 数量 |

| :-- | :-- | :-- |

| access_flags | u2 | 1 |

| name_index | u2 | 1 |

| descriptor_index | u2 | 1 |

| attributes_count | u2 | 1 |

| attributes | attribute_info | attributes_count |

access_flags结构

| 标志名称 | 标志值 | 含义 |

| :-- | :-- | :-- |

| ACC_PUBLIC | 0x0001 | 方法是否为public |

| ACC_PRIVATE | 0x0002 | 方法是否为private |

| ACC_PROTECTED | 0x0004 | 方法是否为protected |

| ACC_STATIC | 0x0008 | 方法是否为static |

| ACC_FINAL | 0x0010 | 方法是否为final |

| ACC_SYNCHRONIZED | 0x0020 | 方法是否为synchronized |

| ACC_BRIDGE | 0x0040 | 方法是否是由编译器产生的桥接方法 |

| ACC_VARARGS | 0x0080 | 字段是否接受不定参数 |

| ACC_NATIVE | 0x0100 | 字段是否为native |

| ACC_ABSTRACT | 0x0400 | 方法是否为abstract |

| ACC_STRICTFP | 0x0800 | 方法是否为strictfp |

| ACC_SYNTHETIC | 0x1000 | 方法是否是由编译器自动产生的 |

name_index

方法定义的名称,注意本案例中我们只定义一个方法"fun1",但是我们发现方法表中有两个方法其中一个是实例的构造器方法。

在这里插入图片描述

descriptor_name

方法描述符,描述方法的参数类型返回值等。描述方法规则 参数列表在前返回值在后

public final class Test2 {

private static final String NAME=“bobo”;

private String users[][];

private int age = 18;

// 描述符 ()V

public void fun1(){

int b = 20;

int c = 30;

int d = b+c+age;

System.out.println(d);

}

// 描述符; (I[Ljava/lang/String[[I)Z

总结:绘上一张Kakfa架构思维大纲脑图(xmind)

![image](https://upload-images.jianshu.io/upload_images/24613101 需要zi料+ 绿色徽【vip1024b】

-254a3cfc19794888.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

其实关于Kafka,能问的问题实在是太多了,扒了几天,最终筛选出44问:基础篇17问、进阶篇15问、高级篇12问,个个直戳痛点,不知道如果你不着急看答案,又能答出几个呢?

若是对Kafka的知识还回忆不起来,不妨先看我手绘的知识总结脑图(xmind不能上传,文章里用的是图片版)进行整体架构的梳理

梳理了知识,刷完了面试,如若你还想进一步的深入学习解读kafka以及源码,那么接下来的这份《手写“kafka”》将会是个不错的选择。

  • Kafka入门

  • 为什么选择Kafka

  • Kafka的安装、管理和配置

  • Kafka的集群

  • 第一个Kafka程序

  • Kafka的生产者

  • Kafka的消费者

  • 深入理解Kafka

  • 可靠的数据传递

  • Spring和Kafka的整合

  • SpringBoot和Kafka的整合

  • Kafka实战之削峰填谷

  • 数据管道和流式处理(了解即可)

image

image

a的消费者

  • 深入理解Kafka

  • 可靠的数据传递

  • Spring和Kafka的整合

  • SpringBoot和Kafka的整合

  • Kafka实战之削峰填谷

  • 数据管道和流式处理(了解即可)

[外链图片转存中…(img-a3YoCMqx-1710345836772)]

[外链图片转存中…(img-1LxbYltX-1710345836772)]

  • 29
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值