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实战之削峰填谷
-
数据管道和流式处理(了解即可)
a的消费者
-
深入理解Kafka
-
可靠的数据传递
-
Spring和Kafka的整合
-
SpringBoot和Kafka的整合
-
Kafka实战之削峰填谷
-
数据管道和流式处理(了解即可)
[外链图片转存中…(img-a3YoCMqx-1710345836772)]
[外链图片转存中…(img-1LxbYltX-1710345836772)]