当前位置: 首页 > news >正文

寻找网站设计与制作企业网络推广计划

寻找网站设计与制作,企业网络推广计划,广州白云网站建设,用别人网站做app的危害运行java代码要经历的三个阶段 反射,程序框架设计的灵魂,将类的各个组成部分封装成其他对象,这就是反射机制。 框架:半成品的软件,在框架的基础上进行开发,可以简化编码 反射的好处: 可以在…
  • 运行java代码要经历的三个阶段

    在这里插入图片描述

  • 反射,程序框架设计的灵魂,将类的各个组成部分封装成其他对象,这就是反射机制。

  • 框架:半成品的软件,在框架的基础上进行开发,可以简化编码

  • 反射的好处:

    1. 可以在程序运行的过程中,操作这些对象
    2. 可以解耦,提高程序的可拓展性
  • 在运行状态中:

    1. 对于任意一个类,都能够知道这个类的所有属性和方法
    2. 对于任意一个对象,都能够调用它的任意属性和方法
  • 与反射机制相关的类

    1. Java.lang.class :代表整个类编译得到的class文件(字节码)
    2. Java.lang.reflect.Method :代表字节码中的方法字节码
    3. Java.lang.reflect.Constructor :代表字节码中的构造器字节码
    4. Java.lang.reflect.Field :代表字节码中的属性字节码
  • 要操作一个字节码,首先要得到这个类的字节码,下面是三种得到字节码的方式

    1. static Class.forName(String className) 这里的className需要时类的全路径,这是一个静态方法

      public class reflect1 {public static void main(String[] args) throws ClassNotFoundException {//第一种方式Class c1=Class.forName("java.lang.String");System.out.println(c1);}
      }
    2. java中的任意一个对象.getClass() ,这个方法继承自Object

      public class reflect1 {public static void main(String[] args) throws ClassNotFoundException {//第一种方式Class c1=Class.forName("java.lang.String");System.out.println(c1);//第二种方式String s="hello";Class c2=s.getClass();System.out.println(c2);}
      }
    3. java语言中的任意一种类型,包括基本数据类型,都有.class属性。

      public class reflect1 {public static void main(String[] args) throws ClassNotFoundException {//第一种方式Class c1=Class.forName("java.lang.String");System.out.println(c1);//第二种方式String s="hello";Class c2=s.getClass();System.out.println(c2);//第三种方式Class c3=String.class;System.out.println(c3);}
      }
    4. JVM在加载一个类的时候,会把这个类的.class字节码文件放在方法区中,栈中放入main方法进行压栈,堆中new出对象c,但是无论使用什么方法获取字节码,一样的class字节码文件只会放一份在方法区中,得到的c变量都是指向方法区中的同一份.class文件。

  • 使用反射机制来实例化对象

  1. 通过Class的newInstance() 方法可以实例化对象

  2. 但是newInstance()方法内部实际上调用了无参构造方法,必须要保证无参构造的存在才可以

        private static void test2() throws InstantiationException, IllegalAccessException {Object o=Student.class.newInstance();System.out.println(o);}
    
  • 反射机制的灵活性,在不修改源码的情况下,可以做到不同对象的实例化,符合OCP开闭原则:对拓展开放,对修改关闭.

    1. 下面的代码中首先利用FileReader读取配置文件,配置文件里面保存了键和值,值是类名,之后new了一个Properties对象,Properties对象的键和值都是String类型,是一种Map数据类型,之后将文件流对象传入Properties对象,再根据键得到值,然后利用反射机制传入类名新建一个对象,实现了对象的灵活创建。
        private static void test3() throws IOException, ClassNotFoundException, InstantiationException, IllegalAccessException {FileReader fr=new FileReader("Student.properties");Properties pro=new Properties();pro.load(fr);fr.close();String forName=pro.getProperty("Student");Class C=Class.forName(forName);Object o=C.newInstance();System.out.println(o);}
    
  • 如果只想要让类里面的某些代码被执行,那么可以使用静态代码和Class.forName,像下面的代码那样,每次类加载器加载一个类的时候,就会先执行静态代码块,使用Class.forName而不用创建类的实例化变量

    public class reflect1 {static {System.out.println("静态代码执行!");}
    }
    
        private static void test4() {try {Class.forName("reflect1");} catch (ClassNotFoundException e) {throw new RuntimeException(e);}}
    
  • 获取文件的类路径,可以通过类加载器获取,具体如下:

        private static void test4() {String path=Thread.currentThread().getContextClassLoader().getResource("a.txt").getPath();System.out.println(path);}
    
  • 资源绑定器

    1. 用来获取属性配置文件中的内容

    2. 属性配置文件必须要放在类路径下(src下面)

    3. 必须是properties后缀

    4. 绑定某个属性配置文件的时候,只需要填写配置文件的名字,不需要写后缀,也不能写后缀

          private static void test4() {ResourceBundle bundle=ResourceBundle.getBundle("Student");String path=bundle.getString("Student");System.out.println(path);}
      
  • 获取并操作属性字节码

    1. 首先获取整个字节码

    2. 利用字节码的getFields可以获取到public修饰的所有属性

    3. 利用字节码的getDeclaredFields可以获取到所有属性,无论什么修饰符都可以获取到

    4. 遍历属性列表

    5. 通过属性.getName()可以获取到属性的名字

    6. 通过属性.getType()可以获取到属性的完整类型,getSimpleName是获取简化的类名

    7. 通过属性.getModifiers()可以获取到属性的修饰符id,通过Modifier.toString(id)就可以拿到完整的修饰符

      import java.io.Serializable;public class Student implements Serializable {
      //    属性设置为privateprivate String name;private int age;private static String room;//无参数构造public Student() {}//有参数构造public Student(String name, int age, String room) {this.name = name;this.age = age;this.room=room;}//getter方法public String getName() {return name;}public int getAge() {return age;}public static String getRoom() {return room;}//setter方法public void setName(String name) {this.name = name;}public void setAge(int age) {this.age = age;}public static void setRoom(String room) {Student.room = room;}//重写equals方法public boolean equals(Object obj){if(obj instanceof Student) {//首先将得到的Object转为Student,否则使用不了Student特有的方法(多态的弊端)Student t = (Student) obj;return t.getAge() == this.getAge() && t.getName() == this.getName() && t.getRoom() == this.getRoom();}return false;}@Overridepublic String toString() {return "Student{" +"name='" + name + '\'' +", age=" + age +'}';}
      }
          private static void test5() throws ClassNotFoundException {//获取整个类Class studentClass=Student.class;//获取public修饰的属性,一个Filed包括private static String room;Field[] fileds=studentClass.getFields();for (Field filed : fileds) {System.out.println(filed);}//获取所有的属性,一个Filed包括private static String room;fileds=studentClass.getDeclaredFields();for (Field filed : fileds) {//获取属性的名字System.out.println("属性的名字:");System.out.println(filed.getName());//获取属性的类型Class filedTypeClass=filed.getType();//getName是获取完整类型,getSimpleName是获取简化的类名String filedType=filedTypeClass.getSimpleName();System.out.println("属性的类型");System.out.println(filedType);//获取属性的修饰符int modify=filed.getModifiers();String modifyName= Modifier.toString(modify);System.out.println("属性的修饰符");System.out.println(modifyName);System.out.println("==================");}}
      
  • 利用反射机制访问一个对象的属性

    1. 要使用反射,当然要先获取一个类的字节码文件

    2. 利用获取到的字节码文件,再用newInstance方法创建一个对象(使用反射的类必须有无参构造)

    3. 利用字节码文件获取这个类的某个属性

    4. 利用这个属性给创建的对象的对应的属性赋值

    5. 在设置对象的属性值之前,需要在使用 set 方法之前,调用 setAccessible(true) 方法来取消对字段的访问权限检查。否则, 会报IllegalAccessException 异常。这是因为 name 字段被声明为 private,无法直接访问。但是使用反射机制绕过访问权限限制可能会导致安全问题。

          private static void test6() throws NoSuchFieldException, InstantiationException, IllegalAccessException {//获取整个类Class studentClass=Student.class;Field filed=studentClass.getDeclaredField("name");Object obj=studentClass.newInstance();filed.setAccessible(true); // 取消对字段的访问权限检查filed.set(obj,"zs");System.out.println(obj);}
      
  • 利用反射机制获取Method

    1. 获取整个类的字节码文件

    2. 通过字节码文件得到方法的字节码,并且遍历它

    3. 通过.getName()获取方法名字

    4. 通过.getReturnType().getSimpleName()获取返回值类型

    5. 通过.getModifiers()获取修饰符id,然后通过Modifier.toString(id)得到修饰符

    6. 通过.getParameterTypes()得到修饰符列表,遍历这个列表,通过.getSimpleName()得到参数名称

          private static void test7() {Class studentClass=Student.class;Method[] methods=studentClass.getDeclaredMethods();for (Method method : methods) {//获取方法名System.out.println("方法名");System.out.println(method.getName());//获取方法的返回值类型System.out.println("方法的返回值类型");System.out.println(method.getReturnType().getSimpleName());//获取修饰符列表System.out.println("方法的修饰符列表");System.out.println(Modifier.toString(method.getModifiers()));//方法的参数列表System.out.println("方法的参数列表");Class[] parametorType= method.getParameterTypes();for (Class aClass : parametorType) {System.out.println(aClass.getSimpleName());}System.out.println("========================");}}
      
  • 通过反射机制操纵Method

    1. 首先获取字节码

    2. 利用得到的字节码新建一个对象

    3. 利用得到的字节码获取一个指定的方法,在java里面,由于存在方法的重载,所以区分一个方法是由方法名+方法参数类型,而不仅仅是方法名,所以使用getDeclaredMethod方法需要一个方法名和若干参数的class

    4. 最后使用这个方法的invoke方法,传入要操纵的对象和实参

          private static void test8() throws InstantiationException, IllegalAccessException, NoSuchMethodException, InvocationTargetException {Class studentClass=Student.class;Object obj=studentClass.newInstance();Method setName=studentClass.getDeclaredMethod("setName",String.class);Object returnVa=setName.invoke(obj,"zs");System.out.println(obj);}
      
  • 通过反射机制获取构造方法

    1. 获取整个类的字节码文件

    2. 通过字节码文件得到构造方法的字节码,并且遍历它

    3. 通过.getName()获取方法名字

    4. 通过.getModifiers()获取修饰符id,然后通过Modifier.toString(id)得到修饰符

    5. 通过.getParameterTypes()得到修饰符列表,遍历这个列表,通过.getSimpleName()得到参数名称

          private static void test9() {Class studentClass=Student.class;Constructor[] constructors=studentClass.getDeclaredConstructors();for (Constructor constructor : constructors) {//获取构造方法名System.out.println("构造方法名");System.out.println(constructor.getName());//获取修饰符列表System.out.println("构造方法的修饰符列表");System.out.println(Modifier.toString(constructor.getModifiers()));//方法的参数列表System.out.println("构造方法的参数列表");Class[] parametorType= constructor.getParameterTypes();for (Class aClass : parametorType) {System.out.println(aClass.getSimpleName());}System.out.println("========================");}}
      
  • 使用反射机制的构造方法创建对象

    1. 直接利用字节码创建(已过时)

    2. 首先获取无参构造函数,然后调用无参构造函数

    3. 首先获取有参构造函数,然后调用有参构造函数

          private static void test10() throws InstantiationException, IllegalAccessException, NoSuchMethodException, InvocationTargetException {//使用反射创建对象//1. 直接利用字节码创建Class studentClass=Student.class;Object t1=studentClass.newInstance();//2. 先利用字节码获取构造函数,然后再利用构造函数创建对象//首先是无参构造Constructor con1=studentClass.getDeclaredConstructor();Object t2=con1.newInstance();//最后是有参构造方法Constructor con2=studentClass.getDeclaredConstructor(String.class,int.class,String.class);Object t3=con2.newInstance("zs",18,"h111");System.out.println(t1);System.out.println(t2);System.out.println(t3);}
      
  • 使用反射获取一个类的父类以及接口

        private static void test11() {Class stringClass=String.class;//获取String的父类Class superClass=stringClass.getSuperclass();System.out.println("父类是");System.out.println(superClass.getSimpleName());//获取接口Class[] interface1=stringClass.getInterfaces();System.out.println("接口是");for (Class aClass : interface1) {System.out.println(aClass.getSimpleName());}}
    

文章转载自:
http://dinncoencrustation.tpps.cn
http://dinncobotany.tpps.cn
http://dinncohexaemeron.tpps.cn
http://dinncononet.tpps.cn
http://dinncolumbersome.tpps.cn
http://dinncosailship.tpps.cn
http://dinncoamphitropous.tpps.cn
http://dinncoegotistic.tpps.cn
http://dinncoinquisitionist.tpps.cn
http://dinncotinder.tpps.cn
http://dinncocigarlet.tpps.cn
http://dinncorhodo.tpps.cn
http://dinncofencing.tpps.cn
http://dinncoschoolteacher.tpps.cn
http://dinncobuffo.tpps.cn
http://dinncoangakok.tpps.cn
http://dinncopromotional.tpps.cn
http://dinncorsv.tpps.cn
http://dinncogusty.tpps.cn
http://dinncopiratical.tpps.cn
http://dinncodisbelieving.tpps.cn
http://dinncoproducibility.tpps.cn
http://dinncoupstand.tpps.cn
http://dinncoexigency.tpps.cn
http://dinncocarbonate.tpps.cn
http://dinncocomplacency.tpps.cn
http://dinncouncondescending.tpps.cn
http://dinncotetromino.tpps.cn
http://dinncohumungous.tpps.cn
http://dinnconetlike.tpps.cn
http://dinncoproceeding.tpps.cn
http://dinncobountifully.tpps.cn
http://dinncoponce.tpps.cn
http://dinncomaffick.tpps.cn
http://dinncorumor.tpps.cn
http://dinncoupheaval.tpps.cn
http://dinncoeaglestone.tpps.cn
http://dinncoenfilade.tpps.cn
http://dinncothomasina.tpps.cn
http://dinncoseamanship.tpps.cn
http://dinncobobtail.tpps.cn
http://dinncoflurazepam.tpps.cn
http://dinncogaedhelic.tpps.cn
http://dinncobeadhouse.tpps.cn
http://dinncoeasygoing.tpps.cn
http://dinncobooklearned.tpps.cn
http://dinncomachicolation.tpps.cn
http://dinncozooful.tpps.cn
http://dinncosuperrational.tpps.cn
http://dinncosupranatural.tpps.cn
http://dinncocholecystography.tpps.cn
http://dinncocheckrail.tpps.cn
http://dinncoclammer.tpps.cn
http://dinncoredigest.tpps.cn
http://dinncofeckless.tpps.cn
http://dinncoshishi.tpps.cn
http://dinnconannoplankton.tpps.cn
http://dinncothirstily.tpps.cn
http://dinncosequitur.tpps.cn
http://dinncopapular.tpps.cn
http://dinncoplaten.tpps.cn
http://dinncononviolence.tpps.cn
http://dinncopastern.tpps.cn
http://dinncoshiveringly.tpps.cn
http://dinncocraggy.tpps.cn
http://dinncofissure.tpps.cn
http://dinncoframed.tpps.cn
http://dinncokayak.tpps.cn
http://dinncoquadrisyllabic.tpps.cn
http://dinncostealing.tpps.cn
http://dinncoessentialist.tpps.cn
http://dinncosaluresis.tpps.cn
http://dinncodryfoot.tpps.cn
http://dinncohypolithic.tpps.cn
http://dinncosculptor.tpps.cn
http://dinncofecal.tpps.cn
http://dinncoauspicial.tpps.cn
http://dinncolittorinid.tpps.cn
http://dinncosparkplug.tpps.cn
http://dinncoregarding.tpps.cn
http://dinncoantimere.tpps.cn
http://dinncomacilent.tpps.cn
http://dinncogettysburg.tpps.cn
http://dinncosympodial.tpps.cn
http://dinncojingoistically.tpps.cn
http://dinncobulgarian.tpps.cn
http://dinncodouane.tpps.cn
http://dinncofuturism.tpps.cn
http://dinncophototonus.tpps.cn
http://dinncoicrp.tpps.cn
http://dinncoleukemia.tpps.cn
http://dinncosilicicolous.tpps.cn
http://dinncosubcelestial.tpps.cn
http://dinncoburble.tpps.cn
http://dinncobantam.tpps.cn
http://dinncostaphylococcus.tpps.cn
http://dinncodandyprat.tpps.cn
http://dinncoinvertin.tpps.cn
http://dinncosonatina.tpps.cn
http://dinncocurtal.tpps.cn
http://www.dinnco.com/news/1409.html

相关文章:

  • 口碑好的网站开发软文代发价格
  • wordpress 中文cms模版成都网站优化及推广
  • 广州网站策划公司最好用的免费建站
  • 一家做公司点评的网站百度推广登录手机版
  • 中电云主机怎样登入创建的网站网站权重怎么提高
  • 郑州做旅游网站福州网站seo
  • 门户网站建设网络推广互联网项目推广平台有哪些
  • 网站怎样做地理位置定位互联网运营推广是做什么的
  • 怎样用阿里云服务器做网站数字营销网站
  • 网站在公安部备案今日热点事件
  • 做网站要那些设备建网站有哪些步骤
  • 网络工程师自学网站公司网站设计要多少钱
  • 新闻网站源码建一个网站需要多少钱?
  • 网站建设 网站推广游戏挂机赚钱一小时20
  • 广州旅游网站建设设计公司营销推广软文
  • 株洲网站建设优度网络推广产品要给多少钱
  • 网站icp备案时间抖音代运营收费详细价格
  • html网站分页怎么做的网站建设案例
  • wordpress免费单页主题seo推广一年要多少钱
  • 北京微信网站开发报价百度免费推广怎么做
  • 系统如何安装wordpress电脑优化系统的软件哪个好
  • 网站建设需要什么书sem扫描电子显微镜
  • 个人网站一年多少钱谷歌seo站内优化
  • 做设计有哪些接私活的网站高端网站优化公司
  • 网站建设运营要求刚刚中国宣布重大消息
  • 四川华地建设工程公司网站免费b站推广网站下载
  • wordpress 问答类主题网站优化排名易下拉软件
  • 保定建行网站首页登录品牌策划与推广
  • 德州网站建设费用简述seo的应用范围
  • wordpress侧边栏工具北京搜索引擎关键词优化