JavaSE基础 —— 反射的基础、Class、Field、Method、Constructor类

例子:

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不过是一种特殊的方法。

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开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

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

image

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

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

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

  • Kafka入门

  • 为什么选择Kafka

  • Kafka的安装、管理和配置

  • Kafka的集群

  • 第一个Kafka程序

  • Kafka的生产者

  • Kafka的消费者

  • 深入理解Kafka

  • 可靠的数据传递

  • Spring和Kafka的整合

  • SpringBoot和Kafka的整合

  • Kafka实战之削峰填谷

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

image

image

《一线大厂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面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门即可获取!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值