首页
统计
关于
Search
1
Sealos3.0离线部署K8s集群
1,086 阅读
2
类的加载
742 阅读
3
Spring Cloud OAuth2.0
726 阅读
4
SpringBoot自动装配原理
691 阅读
5
集合不安全问题
588 阅读
笔记
Java
多线程
注解和反射
JVM
JUC
设计模式
Mybatis
Spring
SpringMVC
SpringBoot
MyBatis-Plus
Elastic Search
微服务
Dubbo
Zookeeper
SpringCloud
Nacos
Sentinel
数据库
MySQL
Oracle
PostgreSQL
Redis
MongoDB
工作流
Activiti7
Camunda
消息队列
RabbitMQ
前端
HTML5
CSS
CSS3
JavaScript
jQuery
Vue2
Vue3
Linux
容器
Docker
Kubernetes
Python
FastApi
登录
Search
标签搜索
Java
CSS
mysql
RabbitMQ
JavaScript
Redis
JVM
Mybatis-Plus
Camunda
多线程
CSS3
Python
Spring Cloud
注解和反射
Activiti
工作流
SpringBoot
Mybatis
Spring
html5
蘇阿細
累计撰写
389
篇文章
累计收到
4
条评论
首页
栏目
笔记
Java
多线程
注解和反射
JVM
JUC
设计模式
Mybatis
Spring
SpringMVC
SpringBoot
MyBatis-Plus
Elastic Search
微服务
Dubbo
Zookeeper
SpringCloud
Nacos
Sentinel
数据库
MySQL
Oracle
PostgreSQL
Redis
MongoDB
工作流
Activiti7
Camunda
消息队列
RabbitMQ
前端
HTML5
CSS
CSS3
JavaScript
jQuery
Vue2
Vue3
Linux
容器
Docker
Kubernetes
Python
FastApi
页面
统计
关于
搜索到
157
篇与
的结果
2020-11-29
类加载器
1.虚拟机自带的加载器2.启动类(根)加载器3.扩展类加载器4.应用程序(系统类)加载器
2020年11月29日
48 阅读
0 评论
0 点赞
2020-11-29
双亲委派机制
当某个类加载器需要加载某个.class文件时,它首先会把这个任务委托给他的上级类加载器,递归这个操作,如果上级的类加载器没有加载,自己才会去加载这个类。1.类加载器收到类加载的请求 2.将这个请求向上委托给父类加载器去完成,一直向上委托,直到启动类加载器 3.启动类加载器检查是否能够加载当前这个类,能加载就结束,使用当前的加载器 否则,抛出异常,通知子类加载器进行加载 4.重复步骤3package java.lang; /** * @Author suaxi * @Date 2020/11/29 12:37 */ public class String { //双亲委派机制 //1.APP --->EXC --->BOOT(最终执行) //BOOT //EXC //APP public String toString(){ return "Hello"; } public static void main(String[] args) { String s = new String(); System.out.println(s.getClass().getClassLoader()); s.toString(); } /* 1.类加载器收到类加载的请求 2.将这个请求向上委托给父类加载器去完成,一直向上委托,直到启动类加载器 3.启动类加载器检查是否能够加载当前这个类,能加载就结束,使用当前的加载器 否则,抛出异常,通知子类加载器进行加载 4.重复步骤3 ClassNotFound null:java调用不到 */ } 此实例会报错无法找到main主方法package java.lang; /** * @Author suaxi * @Date 2020/11/29 12:55 */ public class Student { @Override public String toString() { return "Hello"; } public static void main(String[] args) { Student s = new Student(); System.out.println(s.toString()); } } 双亲委派机制的作用:1.防止重复加载同一个.class2.保证核心.class不会被篡改
2020年11月29日
43 阅读
0 评论
0 点赞
2020-11-29
JVM体系结构
栈、本地方法栈、程序计数器不能有垃圾回收JVM调优在方法区和堆中进行,且大部分在堆中操作
2020年11月29日
58 阅读
0 评论
0 点赞
2020-11-29
JVM的位置
暂无简介
2020年11月29日
46 阅读
0 评论
0 点赞
2020-11-28
动态创建对象执行方法
动态创建对象执行方法1、创建类的对象:调用Class对象的newInstance()方法类必须有无参构造器需要构造器的访问权限 //获得Class对象 Class c1 = Class.forName("com.sw.reflection.User"); //构造一个对象 User user = (User) c1.newInstance(); //本质是调用类的无参构造 System.out.println(user);2、在没有无参构造器的情况下,只要在操作的时候明确的调用类中的构造器并将参数传递进去,就可以实例化操作通过Class类的getDeclaredConstructor(Class ... parameterTypes)取得本类的指定形参类型的构造器向构造器的形参中传递一个对象数组进去,里面包含了构造器中所需的各个参数通过Constructor实例化对象 //获得Class对象 Class c1 = Class.forName("com.sw.reflection.User"); //通过构造器创建对象 Constructor constructor = c1.getDeclaredConstructor(int.class, String.class, int.class); User user1 = (User) constructor.newInstance(1, "孙笑川", 30); System.out.println(user1);3、调用指定的方法通过反射调用类中的方法,通过Method类完成通过Class类的getMethod(String name,parameterTypes)方法取得一个Method对象,并设置此方法操作时所需要的参数类型之后使用Object invoke(Object obj,Object[] args)进行调用,并向方法中传递要设置的obj对象的参数信息Object invoke(Object obj,Object[] args)Object对应原方法的返回值,若原方法无返回值,则返回null若原方法为静态方法,此时形参Object obj可为null若原方法形参列表为空,则Object[] args为null若原方法声明为private,则需要在调用invoke方法前,显示调用方法对象的setAccessible(true)方法,关闭程序的安全检查setAccessibleMethod和Field、Constructor对象都有setAccessible方法其作用是启动和禁止访问安全检查的开关参数值为true时指反射的对象在使用时应该取消Java语言访问检查提高反射的效率使原本无法访问的private私有成员也可以访问参数值为fasle指反射的对象应执行Java语言访问检查(默认值为false) //获得Class对象 Class c1 = Class.forName("com.sw.reflection.User"); //通过反射调用普通方法 User user2 = (User) c1.newInstance(); //通过反射获取一个方法 Method setName = c1.getDeclaredMethod("setName", String.class); //invoke 激活 //.invoke(对象,"值") setName.invoke(user2,"孙笑川"); System.out.println(user2.getName());整个实例Demo:package com.sw.reflection; import java.lang.reflect.Constructor; import java.lang.reflect.Field; import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; /** * @Author suaxi * @Date 2020/11/28 14:31 * 通过反射,动态的创建对象 */ public class Test09 { public static void main(String[] args) throws ClassNotFoundException, IllegalAccessException, InstantiationException, NoSuchMethodException, InvocationTargetException, NoSuchFieldException { //获得Class对象 Class c1 = Class.forName("com.sw.reflection.User"); //构造一个对象 //User user = (User) c1.newInstance(); //本质是调用类的无参构造 //System.out.println(user); //通过构造器创建对象 //Constructor constructor = c1.getDeclaredConstructor(int.class, String.class, int.class); //User user1 = (User) constructor.newInstance(1, "孙笑川", 30); //System.out.println(user1); //通过反射调用普通方法 User user2 = (User) c1.newInstance(); //通过反射获取一个方法 Method setName = c1.getDeclaredMethod("setName", String.class); //invoke 激活 //.invoke(对象,"值") setName.invoke(user2,"孙笑川"); System.out.println(user2.getName()); //通过反射操作属性 User user3 = (User) c1.newInstance(); Field name = c1.getDeclaredField("name"); //不能直接操作私有属性,需关掉程序的安全检测,属性/方法.setAccessible(true); name.setAccessible(true); name.set(user3,"药水哥"); System.out.println(user3.getName()); } }
2020年11月28日
77 阅读
0 评论
0 点赞
2020-11-27
类加载器
类加载器1、作用:将class文件字节码内容加载到内存中,并将这些静态数据转换成方法区的运行时数据结构,然后在堆中生成一个代表这个类的java.lang.Class对象,作为方法区中类数据的访问入口2、类缓存:标准的JavaSE类加载器可以按要求查找类,但一旦某个类被加载到类加载器中,它将维持加载(缓存)一段时间,JVM垃圾回收机制可以回收这些Class对象3、类加载器作用是用来把类(class)装载进内存,JVM规范定义了如下类型的类加载器package com.sw.reflection; /** * @Author suaxi * @Date 2020/11/27 21:29 */ public class Test07 { public static void main(String[] args) throws ClassNotFoundException { //获取系统类的加载器 ClassLoader systemClassLoader = ClassLoader.getSystemClassLoader(); System.out.println(systemClassLoader); //获取系统类加载器的父类加载器 --->扩展类加载器 ClassLoader parent = systemClassLoader.getParent(); System.out.println(parent); //获取扩展类加载器的父类加载器 --->根加载器(C/c++编写,无法直接获取) ClassLoader parent1 = parent.getParent(); System.out.println(parent1); //测试当前类是哪个加载器加载的 ClassLoader classLoader = Class.forName("com.sw.reflection.Test07").getClassLoader(); System.out.println(classLoader); //测试JDK内置的类是谁加载的 classLoader = Class.forName("java.lang.Object").getClassLoader(); System.out.println(classLoader); //获取系统类加载器可以加载的路径 System.out.println(System.getProperty("java.class.path")); } }
2020年11月27日
69 阅读
0 评论
0 点赞
2020-11-27
类初始化
什么时候会发生类初始化?1、主动引用(一定会发生类的初始化)当虚拟机启动时,先初始化main方法所在的类new一个对象时调用类的静态成员(final常量除外)和静态方法使用java.lang.reflection包的方法对类进行反射调用当初始化一个类,如果其父类没有被初始化,则会先初始化它的父类2、被动引用(不会发生类的初始化)当访问一个静态域时,只有真正声明这个域的类才会被初始化。如:通过子类引用父类的静态变量,不会导致子类被初始化通过数组定义类引用引用常量(常量在链接阶段就已经存入调用类的常量池中了)package com.sw.reflection; import java.lang.reflect.Array; /** * @Author suaxi * @Date 2020/11/27 17:21 * 测试类什么时候会初始化 */ public class Test06 { static { System.out.println("Main方法被加载"); } public static void main(String[] args) throws ClassNotFoundException { //1、主动引用 //Son son = new Son(); //2、反射(也会产生主动引用) //Class.forName("com.sw.reflection.Son"); //不会产生类的 引用的方法 //System.out.println(Son.b); //数组 //Son[] s = new Son[5]; //常量 System.out.println(Son.M); } } class Father{ static int b = 2; static { System.out.println("父类被加载"); } } class Son extends Father{ static { System.out.println("子类被加载"); m =300; } static int m = 100; static final int M = 1; }主动引用反射子类引用父类的静态变量数组常量(子类中的final类)
2020年11月27日
65 阅读
0 评论
0 点赞
2020-11-27
类的加载与ClassLoader
类的加载与ClassLoader1、加载:将class文件字节码内容加载到内存中,并将这些静态数据转换成方法区的运行时数据结构,之后生成一个代表这个类的java.lang.Class对象2、链接:将Java类的二进制代码合并到JVM的运行状态之中的过程验证:确保加载的类信息符合JVM规范准备:正式为类变量(static)分配内存并设置类变量默认初始值的阶段,注:这些内存都将在方法区中进行分配解析:虚拟机常量池内的符号引用(常量名)替换为直接引用(地址)的过程3、初始化:执行类构造器()方法的过程。类构造器()方法是由编译器自动收集类中所有类变量的赋值动作和静态代码块中的语句所产生的(类构造器是构造类信息的,不是构造该类对象的构造器)当初始化一个类的时候,如果发现其父类还没有进行初始化,则需要先触发其父类的初始化虚拟机会保证一个类的()方法在多线程环境中被正确加锁和同步package com.sw.reflection; /** * @Author suaxi * @Date 2020/11/27 16:56 */ public class Test05 { public static void main(String[] args) { A a = new A(); System.out.println(a.m); /* 1、加载到内存,产生一个Class对象 2、链接,链接结束后 m=0 3、初始化 <clinit>{ System.out.println("A类静态代码块初始化"); m = 300; } m = 100; */ } } class A{ static { System.out.println("A类静态代码块初始化"); m = 300; } static int m = 100; public A(){ System.out.println("A类的无参构造初始化"); } }
2020年11月27日
181 阅读
0 评论
0 点赞
1
...
15
16
17
...
20