java反射_01
为什么要用反射?
举个栗子:
package com.imooc.reflect; public class Work { // 定义一个word方法 public void word() { System.out.println("厉害了word哥"); } }
package com.imooc.reflect; public class Word { public static void main(String[] args) { Work work = new Work(); work.word(); // 厉害了word哥 work.excel(); // 报错,因为work类中没有这个方法 } }
我们希望既然定义了word方法就能使用该方法,而不受是否有excel()方法的影响。
反射的作用就是避开编译期不通过的影响,运行期需要调用word()方法就能调用,不用管excel()方法是否存在。
编译时刻加载类是静态加载类、运行时刻加载类是动态加载类。
动态加载类的三种方式:
1 package com.imooc.reflect; 2 3 public class ClassDemo1 { 4 5 public static void main(String[] args) { 6 //Foo的实例对象如何表示 7 Foo foo1 = new Foo(); 8 //Foo这个类 也是一个实例对象,Class类的实例对象,如何表示呢 9 //任何一个类都是Class的实例对象,这个实例对象有三种表示方式 10 11 //第一种表示方式--->实际在告诉我们任何一个类都有一个隐含的静态成员变量class 12 Class c1 = Foo.class; 13 14 //第二中表达方式 已经知道该类的对象通过getClass方法 15 Class c2 = foo1.getClass(); 16 17 /* 18 * c1 ,c2 表示了Foo类的类类型(class type) 19 * 万事万物皆对象, 20 * 类也是对象,是Class类的实例对象 21 * 这个对象我们称为该类的类类型 22 * 23 */ 24 25 //不管c1 or c2都代表了Foo类的类类型,一个类只可能是Class类的一个实例对象 26 System.out.println(c1 == c2); 27 28 //第三种表达方式 29 Class c3 = null; 30 try { 31 c3 = Class.forName("com.imooc.reflect.Foo"); 32 } catch (ClassNotFoundException e) { 33 // TODO Auto-generated catch block 34 e.printStackTrace(); 35 } 36 System.out.println(c3 == c2); 37 38 //我们完全可以通过类的类类型创建该类的对象实例---->通过c1 or c2 or c3创建Foo的实例对象 39 Foo foo; 40 try { 41 foo = (Foo)c1.newInstance();//需要有无参数的构造方法 42 foo.print(); 43 } catch (InstantiationException e) { 44 // TODO Auto-generated catch block 45 e.printStackTrace(); 46 } catch (IllegalAccessException e) { 47 // TODO Auto-generated catch block 48 e.printStackTrace(); 49 } 50 } 51 } 52 53 class Foo{ 54 void print() { 55 System.out.println("hahahahahaha"); 56 } 57 }
以上是自己在慕课网学习java反射的一点点理解,肯定不精准,只是为了快速理解反射。毕竟越简单越方便入门。等自己达到一定水平再追求精确吧。希望读到此篇的同学,不要太把本文太当真,理解就好。
java反射_01的更多相关文章
- 第28章 java反射机制
java反射机制 1.类加载机制 1.1.jvm和类 运行Java程序:java 带有main方法的类名 之后java会启动jvm,并加载字节码(字节码就是一个类在内存空间的状态) 当调用java命令 ...
- Java反射机制
Java反射机制 一:什么事反射机制 简单地说,就是程序运行时能够通过反射的到类的所有信息,只需要获得类名,方法名,属性名. 二:为什么要用反射: 静态编译:在编译时确定类型,绑定对象,即通过 ...
- java反射(基础了解)
package cn.itcast_01; /** *Person类 */ public class Person { /** 姓名 */ private String name; ...
- java基础知识(十一)java反射机制(上)
java.lang.Class类详解 java Class类详解 一.class类 Class类是java语言定义的特定类的实现,在java中每个类都有一个相应的Class对象,以便java程序运行时 ...
- java基础知识(十一)java反射机制(下)
1.什么是反射机制? java反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法,对于任意一个对象都能够调用他的属性和方法,这种动态获取属性和方法的功能称为java的反射机制. ...
- java反射学习之二万能EXCEL导出
一.EXCEL导出的实现过程 假设有一个对象的集合,现在需要将此集合内的所有对象导出到EXCEL中,对象有N个属性:那么我们实现的方式是这样的: 循环这个集合,在循环集合中某个对象的所有属性,将这个对 ...
- java反射学习之一反射机制概述
一.反射机制背景概述 1.反射(reflection)是java被视为动态语言的一个关键性质 2.反射机制指的是程序在运行时能获取任何类的内部所有信息 二.反射机制实现功能概述 1.只要给定类的全名, ...
- java反射 之 反射基础
一.反射 反射:JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法:对于任意一个对象,都能够调用它的任意一个方法和属性:这种动态获取的信息以及动态调用对象的方法的功能称为 ...
- java反射 cglib asm相关资料
有篇文章对java反射的调用的效率做了测试,写的比较好.猛击下面地址 http://www.blogjava.net/stone2083/archive/2010/09/15/332065.html ...
随机推荐
- Python-程序的控制结构
程序的分支结构 >单分支结构 根据判断条件结果而选择不同向前路径的运行方式 if <条件>: <语句块> 代码示例: guess = eval(input()) if g ...
- hdu 5178 pairs
pairs 问题描述 John 在X轴上拥有nn个点,他们的坐标分别为$(x[i],0),(i=0,1,2,…,n-1)$. 他想知道有多少对< a,b ><a,b>满足|x[ ...
- BZOJ 1444 [JSOI2009]有趣的游戏 (AC自动机、概率与期望DP、矩阵乘法)
诶这题洛谷居然没有??? 题目链接: https://www.lydsy.com/JudgeOnline/problem.php?id=1444 题解: 我见到主要有三种做法. 一是矩阵乘法.设\(d ...
- [Bzoj4195] [NOI2015] 程序自动分析 [并查集,哈希,map] 题解
用并查集+离散化,注意:并查集数组大小不是n而是n*2 #include <iostream> #include <algorithm> #include <cstdio ...
- BZOJ1192 鬼谷子的钱袋
没想到这是一道省选题... /* BZOJ1192 */ #include <cstdio> int main() { ; scanf("%d",&m); ;m ...
- 用循环链表实现Josephus问题
Josephus问题:设有n个人围坐在一个圆桌周围,现从第s个人开始报数,数到第m的人出列,然后从出列的下一个人重新开始报数,数到第m的人又出列.如此反复直到所有的人全部出列为止. 思路:构建一个没有 ...
- nyoj_171_聪明的kk_201402281518
聪明的kk时间限制:1000 ms | 内存限制:65535 KB 难度:3描述 聪明的“KK”非洲某国展馆的设计灵感源于富有传奇色彩的沙漠中陡然起伏的沙丘,体现出本国不断变换和绚丽多彩的自然风光 ...
- POJ 3061 Subsequence 尺取
Subsequence Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 14698 Accepted: 6205 Desc ...
- Linux环境变量设置中配置文件分析(/etc/profile,~/.bashrc等)(转)
说明:在研究中发现,对于不同版本的Linux系统有着不同的文件,但是总的入口是不变的/etc/profile,下面只是展示加载顺序的研究过程,所以会有些系统没有这个文件等问题. 一.配置文件与作用域: ...
- zoj1940
链接:点击打开链接 题意:三维搜索'S'为起点,'E'为终点,求走出的最短时间 代码: #include <iostream> #include <stdio.h> #incl ...