例子:
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
class Student {
public String name;
public int age;
public Student(String name, int age) {
this.name = name;
this.age = age;
}
public void setAge(int age) {
this.age = age;
}
public static void show(){
System.out.println(“show information”);
}
}
public class Test2 {
public static void main(String[] args) {
Student student = new Student(“Mike”, 18);
Class cl = Student.class;
try {
// 实例有参方法
Method setAgeMethod = cl.getMethod(“setAge”, int.class) ;
setAgeMethod.invoke(student,28);
System.out.println(student.age);
// 静态无参方法
Method showMethod = cl.getMethod(“show”);
showMethod.invoke(null);
} catch (NoSuchMethodException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (InvocationTargetException e) {
e.printStackTrace();
}
}
}
这种方法调用的缺点是明显的。
一是,参数和返回值都是Object,需要来回强制转换。
二是,这样调用方法本身就是兜了个圈子,很耗时。
与Method对象类似,Constructor不过是一种特殊的方法。
几个重要的方法原型。
// 获取构造器
public Constructor getConstructor(Class<?>… parameterTypes);
// 根据构造器生成实例
public T newInstance(Object … initargs)
举例。
import java.lang.reflect.Constructor;
import java.lang.reflect.InvocationTargetException;
class Student {
public String name;
public int age;
public Student(String name, int age) {
this.name = name;
this.age = age;
}
@Override
public String toString() {
return “Student{” +
“name='” + name + ‘’’ +
“, age=” + age +
‘}’;
}
}
public class Test2 {
public static void main(String[] args) {
Class cl = Student.class;
try {
Constructor constructor = cl.getConstructor(String.class,int.class);
Student student = (Student) constructor.newInstance(“Jack”,18);
System.out.println(student);
} catch (NoSuchMethodException | IllegalAccessException | InstantiationException | InvocationTargetException e) {
e.printStackTrace();
}
}
}
附:《Java核心技术卷》书上的源代码:
package about_reflect;
import java.lang.reflect.Constructor;
import java.lang.reflect.Field;
import java.lang.reflect.Method;
import java.lang.reflect.Modifier;
public class ClassAnalyzer {
private Class cl;
public ClassAnalyzer(Class clazz) {
this.cl = clazz;
}
// 输出所有的构造器(包括 private 、 protected)
public void printConstructors() {
Constructor[] constructors = cl.getDeclaredConstructors();
for(Constructor c:constructors){
String name = c.getName();
System.out.print(" ");
String modifiers = Modifier.toString(c.getModifiers());
if(modifiers.length()>0) System.out.print(modifiers+" ");
System.out.print(name+“(”);
Class[] paramTypes = c.getParameterTypes();
for(int j=0;j<paramTypes.length;j++){
if(j>0) System.out.print(", ");
System.out.print(paramTypes[j].getName());
}
System.out.println(“);”);
}
System.out.println();
}
// 输出在这个类中的所有的方法
public void printMethods() {
Method[] methods = cl.getDeclaredMethods();
for(Method m:methods){
Class retype = m.getReturnType();
String methodName = m.getName();
System.out.print(" ");
String modifiers = Modifier.toString(m.getModifiers());
if(modifiers.length()>0){
System.out.print(modifiers+" ");
}
System.out.print(retype.getName()+" “+methodName+”(");
Class[] params = m.getParameterTypes();
for(int j=0;j<params.length;j++){
if(j>0) System.out.print(", ");
System.out.print(params[j].getName());
}
System.out.println(“);”);
}
System.out.println();
}
// 输出在这个类中的所有的字段
public void printFields() {
Field[] fields = cl.getDeclaredFields();
for(Field field:fields) {
System.out.print(" ");
Class type = field.getType();
String modifiers = Modifier.toString(field.getModifiers());
if(modifiers.length()>0) System.out.print(modifiers+" ");
System.out.println(type.getName()+" “+field.getName()+”;");
}
System.out.println();
}
public void display() {
Class supercl = cl.getSuperclass();
String modifiers = Modifier.toString(cl.getModifiers());
if(modifiers.length()>0) System.out.print(modifiers+" ");
System.out.print("class "+cl.getName());
if(supercl != null && supercl != Object.class){
System.out.print(" extends "+supercl.getName());
}
System.out.println(" {\n");
printFields();
printConstructors();
printMethods();
System.out.println(“}”);
}
}
测试代码:
import about_reflect.ClassAnalyzer;
import java.util.Scanner;
public class Test {
public static void main(String[] args) {
try(var in = new Scanner(System.in)){
ClassAnalyzer classAnalyzer;
String classname = in.next();
try {
classAnalyzer = new ClassAnalyzer(Class.forName(classname));
} catch (ClassNotFoundException e) {
System.out.println(“此类未找到”);
return;
}
classAnalyzer.display();
}
}
}
运行结果为:
java.lang.String
public final class java.lang.String {
private final [B value;
private final byte coder;
private int hash;
private static final long serialVersionUID;
static final boolean COMPACT_STRINGS;
private static final [Ljava.io.ObjectStreamField; serialPersistentFields;
public static final java.util.Comparator CASE_INSENSITIVE_ORDER;
static final byte LATIN1;
static final byte UTF16;
public java.lang.String([B);
public java.lang.String([B, int, int);
public java.lang.String([B, java.nio.charset.Charset);
public java.lang.String([B, java.lang.String);
public java.lang.String([B, int, int, java.nio.charset.Charset);
java.lang.String([C, int, int, java.lang.Void);
java.lang.String(java.lang.AbstractStringBuilder, java.lang.Void);
public java.lang.String(java.lang.StringBuilder);
public java.lang.String(java.lang.StringBuffer);
java.lang.String([B, byte);
public java.lang.String([C, int, int);
public java.lang.String([C);
public java.lang.String(java.lang.String);
public java.lang.String();
public java.lang.String([B, int, int, java.lang.String);
public java.lang.String([B, int);
public java.lang.String([B, int, int, int);
public java.lang.String([I, int, int);
[B value();
public boolean equals(java.lang.Object);
public int length();
public java.lang.String toString();
public int hashCode();
public void getChars(int, int, [C, int);
public int compareTo(java.lang.String);
public volatile int compareTo(java.lang.Object);
public int indexOf(java.lang.String, int);
public int indexOf(int);
static int indexOf([B, byte, int, java.lang.String, int);
public int indexOf(int, int);
public int indexOf(java.lang.String);
static void checkIndex(int, int);
public static java.lang.String valueOf(int);
public static java.lang.String valueOf(float);
public static java.lang.String valueOf(boolean);
public static java.lang.String valueOf(long);
public static java.lang.String valueOf(double);
public static java.lang.String valueOf(java.lang.Object);
public static java.lang.String valueOf(char);
public static java.lang.String valueOf([C);
public static java.lang.String valueOf([C, int, int);
byte coder();
private static java.lang.Void rangeCheck([C, int, int);
public java.util.stream.IntStream codePoints();
public boolean isEmpty();
public char charAt(int);
public int codePointAt(int);
public int codePointBefore(int);
public int codePointCount(int, int);
public int offsetByCodePoints(int, int);
public [B getBytes(java.nio.charset.Charset);
public void getBytes(int, int, [B, int);
public [B getBytes(java.lang.String);
public [B getBytes();
void getBytes([B, int, byte);
public boolean contentEquals(java.lang.StringBuffer);
public boolean contentEquals(java.lang.CharSequence);
private boolean nonSyncContentEquals(java.lang.AbstractStringBuilder);
public boolean equalsIgnoreCase(java.lang.String);
public int compareToIgnoreCase(java.lang.String);
public boolean regionMatches(boolean, int, java.lang.String, int, int);
public boolean regionMatches(int, java.lang.String, int, int);
public boolean startsWith(java.lang.String);
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)
![img](https://img-blog.csdnimg.cn/img_convert/155de56f8fcb834d902ce8176f889d8d.jpeg)
总结:绘上一张Kakfa架构思维大纲脑图(xmind)
其实关于Kafka,能问的问题实在是太多了,扒了几天,最终筛选出44问:基础篇17问、进阶篇15问、高级篇12问,个个直戳痛点,不知道如果你不着急看答案,又能答出几个呢?
若是对Kafka的知识还回忆不起来,不妨先看我手绘的知识总结脑图(xmind不能上传,文章里用的是图片版)进行整体架构的梳理
梳理了知识,刷完了面试,如若你还想进一步的深入学习解读kafka以及源码,那么接下来的这份《手写“kafka”》将会是个不错的选择。
-
Kafka入门
-
为什么选择Kafka
-
Kafka的安装、管理和配置
-
Kafka的集群
-
第一个Kafka程序
-
Kafka的生产者
-
Kafka的消费者
-
深入理解Kafka
-
可靠的数据传递
-
Spring和Kafka的整合
-
SpringBoot和Kafka的整合
-
Kafka实战之削峰填谷
-
数据管道和流式处理(了解即可)
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》,点击传送门即可获取!
OQE-1712113575275)]
其实关于Kafka,能问的问题实在是太多了,扒了几天,最终筛选出44问:基础篇17问、进阶篇15问、高级篇12问,个个直戳痛点,不知道如果你不着急看答案,又能答出几个呢?
若是对Kafka的知识还回忆不起来,不妨先看我手绘的知识总结脑图(xmind不能上传,文章里用的是图片版)进行整体架构的梳理
梳理了知识,刷完了面试,如若你还想进一步的深入学习解读kafka以及源码,那么接下来的这份《手写“kafka”》将会是个不错的选择。
-
Kafka入门
-
为什么选择Kafka
-
Kafka的安装、管理和配置
-
Kafka的集群
-
第一个Kafka程序
-
Kafka的生产者
-
Kafka的消费者
-
深入理解Kafka
-
可靠的数据传递
-
Spring和Kafka的整合
-
SpringBoot和Kafka的整合
-
Kafka实战之削峰填谷
-
数据管道和流式处理(了解即可)
[外链图片转存中…(img-POobWEhY-1712113575275)]
[外链图片转存中…(img-7oAH9Uf6-1712113575275)]
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》,点击传送门即可获取!