枚举类

枚举类是优化定义固定对象的一种特殊的类。

换句话说,在需要类的实例为一个或者多个并且相对固定的时候,使用枚举类。(枚举类可扩展)

类的实例相对来说固定的有日期,客观不变的一些数字等等。

enum WorkDay
{
MONDAY, THUEDAY, WEDNESDAY , THURSDAY , FRIDAY;
} public class Main { public static void main(String[] args) {
System.out.println("Hello World!"); WorkDay workDay; workDay=WorkDay.MONDAY; //WorkDay实例化的workday值限定在周一到周五之间 // workDay=3; //编译报错 WorkDay []workDays = WorkDay.values(); //返回枚举类型的对象数组 for(int i =0;i<workDays.length;i++)
{
System.out.println(workDays[i]);
} /**
* 单例模式是枚举类的特例,单例模式的要求是一个类只能由一个实例对象。
* 枚举类的使用是定义类时固定其一个或多个对象
*
* 枚举类的特点:
* - 类型安全(枚举类的定义就是固定的)
* - 枚举类的对象自动添加private static final
* - 某种程度的解耦,枚举类可以加一组常量或者对象抽离出主程序,减小类之间的耦合性。在枚举类模板的扩展上也更加容易
*/ }
}

注解

Annotation 是代码里的特殊标记, 这些标记可以在编译, 类加 载, 运行时被读取, 并执行相应的处理。

基本注解

  • @Override 重写注解
  • @Deprecated 过时注解
  • @SuppressWarnings 抑制编译器警告注解

反射

什么是反射?

反射机制允许程序在运行期 借助于Reflection API取得任何类的内部信息,并能直接操作任意对象的内部属性及方法。 (最高权限)

Object类

package java.lang;

public class Object {

   private static native void registerNatives();
static {
registerNatives();
} public final native Class<?> getClass(); public native int hashCode(); public boolean equals(Object obj) {
return (this == obj);
} protected native Object clone() throws CloneNotSupportedException; public String toString() {
return getClass().getName() + "@" + Integer.toHexString(hashCode());
} public final native void notify(); public final native void notifyAll(); public final native void wait(long timeout) throws InterruptedException; public final void wait(long timeout, int nanos) throws InterruptedException {
if (timeout < 0) {
throw new IllegalArgumentException("timeout value is negative");
} if (nanos < 0 || nanos > 999999) {
throw new IllegalArgumentException(
"nanosecond timeout value out of range");
} if (nanos > 0) {
timeout++;
} wait(timeout);
} public final void wait() throws InterruptedException {
wait(0);
} protected void finalize() throws Throwable { }
}

其中有一个这样的方法

public final native Class<?> getClass();

获取Class类的实例

  • 若已知具体的类,通过类的class属性获取,该方法最为安全可靠, 程序性能最高

  • 已知某个类的实例,调用该实例的getClass()方法获取Class对象

  • 已知一个类的全类名,且该类在类路径下,可通过Class类的静态方 法forName()获取,可能抛出ClassNotFoundException

    Class test  = String.class;
    
    Class test01 = "Hello World!".getClass();
    
    Class test02 = Class.forName("java.lang.String");  //抛异常

所有的类都继承Object,所以String.class返回类的实例。

Class类里有一个forName的方法,返回值也为Class:

获取类的信息,调用类的属性及方法

package test;

import java.lang.reflect.Field;
import java.lang.reflect.Method; class Work {
private String name;
private Integer age;
private String gender;
private String job; public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public Integer getAge() {
return age;
} public void setAge(Integer age) {
this.age = age;
} public String getGender() {
return gender;
} public void setGender(String gender) {
this.gender = gender;
} public String getJob() {
return job;
} public void setJob(String job) {
this.job = job;
} @Override
public String toString() {
return "Work{" +
"name='" + name + '\'' +
", age=" + age +
", gender='" + gender + '\'' +
", job='" + job + '\'' +
'}';
}
} public class ReflectWork
{ public static void main(String[] args) throws IllegalAccessException, InstantiationException, ClassNotFoundException { Class classWork = Class.forName("test.Work"); System.out.println(" ///获取所有方法信息"
); Method []methods= classWork.getDeclaredMethods(); for (Method m:methods) {
System.out.println(m.toString()); } System.out.println(" //获取所有成员属性信息"); Field[] field=classWork.getDeclaredFields();
for(Field f:field){
System.out.println(f.toString()); f.setAccessible(true); //取消类的私有属性的访问权限控制 System.out.println(f.getName().toString());
} System.out.println("//通过反射初始化");
Work reflectWork = (Work) classWork.newInstance();
reflectWork.setAge(22);
reflectWork.setJob("Dev");
Work work = reflectWork; System.out.println(work); }
}

反射的优缺点

反射:就是正在运行动态读取这个类的完整信息。

优点:java的反射机制就是增加程序的灵活性、

缺点:

(1)性能问题:使用反射基本上是一种解释操作,

用于字段和方法接入时要远慢于直接代码。因此反射机制主要应用在对灵活性和扩展性要求很高的系统框架上,普通程序不建议使用。

(2)使用反射会模糊程序内部逻辑:程序员希望在源代码中看到程序的逻辑,反射等绕过了源代码的技术,因而会带来维护问题。反射代码比相应的直接代码更复杂。

哪些地方用到了反射?

例如: jdbc、Java常用框架、jdk的动态代理、android的加载布局文件

枚举类&&注解&&反射的更多相关文章

  1. Enum枚举类|注解Annotation

    Enum枚举类 ①枚举类和普通类的差别: 使用 enum 定义的枚举类默认继承了 java.lang.Enum 类 枚举类的构造器仅仅能使用 private 訪问控制符 枚举类的全部实例必须在枚举类中 ...

  2. 第8章 枚举类&注解

    8.枚举及注解 8.1 如何自定义枚举类 1课时 8.2 如何使用关键字enum定义枚举类 1课时 8.3 枚举类的主要方法 1课时 8.4 实现接口的枚举类 1课时 8-1 枚举类 枚举类入门 枚举 ...

  3. Java枚举类、注解和反射

    本文主要介绍的是枚举类,注解和反射.还有一些基础知识:static,基本数据类型,运算符优先级放在文中,以便查阅复习. 其中牵扯到泛型的部分,可参考本人的另一篇博客:(Collection, List ...

  4. Java语法基础学习DayThirteen(枚举类和注解)

    一.枚举类 1.概述:即一个类中只能有有限个对象,若只有一个对象,则可以作为单例模式的一种实现. 2.自定义枚举类(JDK1.5以前这么做) //枚举类 class Season{ //1.提供类的属 ...

  5. Java枚举类和注解梳理

    1. 枚举类 1. 枚举类的使用 枚举类的理解:类的对象只有有限个,确定的.我们称此类为枚举类. 当需要定义一组常量时,强烈建议使用枚举类. 如果枚举类中只有一个对象,则可以作为单例模式的实现方式. ...

  6. Java笔记---枚举类和注解

    Java笔记---枚举类和注解 一.枚举类 自定义枚举类 方式一:JDK5.0之前自定义枚举类 class Seasons { //1. 声明Seasons对象的属性 private final St ...

  7. JAVASE(十一) 高级类特性: abstract 、模板模式、interface、内部类、枚举、注解

    个人博客网:https://wushaopei.github.io/    (你想要这里多有) 1.关键字 abstract 1.1.abstract可以修饰:类,方法 1.2.abstract修饰方 ...

  8. 【Java基础】枚举类与注解

    枚举类与注解 枚举类的使用 当需要定义一组常量时,强烈建议使用枚举类. 枚举类的理解:类的对象只有有限个,确定的. 若枚举只有一个对象, 则可以作为一种单例模式的实现方式. 枚举类的属性: 枚举类对象 ...

  9. Java枚举类与注解详解——一篇文章读懂枚举类与注解详

    目录 一.枚举类 ① 自定义枚举类 ② enum关键字定义枚举类 ③ enum 枚举类的方法 ④ enum 枚举类实现接口 二.注解 ① 生成文档相关注解 ②注解在编译时进行格式检查 ③注解跟踪代码的 ...

随机推荐

  1. Flutter学习笔记(9)--组件Widget

    如需转载,请注明出处:Flutter学习笔记(9)--组件Widget 在Flutter中,所有的显示都是Widget,Widget是一切的基础,我们可以通过修改数据,再用setState设置数据(调 ...

  2. android实现倒计时,最简单实现RecyclerView倒计时+SwipeRefreshLayout下拉刷新

    先上效果图: RecyclerView + SwipeRefreshLayout 实现倒计时效果 MainActivity.java package top.wintp.counttimedemo1; ...

  3. 2019暑假集训 BLO

    题目描述 Byteotia城市有n个 towns m条双向roads. 每条 road 连接 两个不同的 towns ,没有重复的road. 所有towns连通. 输入 输入n<=100000 ...

  4. 2019牛客多校第一场 E-ABBA(dp)

    ABBA 题目传送门 解题思路 用dp[i][j]来表示前i+j个字符中,有i个A和j个B的合法情况个数.我们可以让前n个A作为AB的A,因为如果我们用后面的A作为AB的A,我们一定也可以让前面的A对 ...

  5. python基础之元祖、嵌套,for循环、 enumerate、range的试用案例

    元祖又叫做只读列表,可循环查询.可切片,元祖里的直接元素不能更改,但是若里面有嵌套的列表,则可以修改列表里的元素 tu = (1,2,3,'sun',[3,4,5,'cat']) tu[4][3] = ...

  6. Ubuntu16.04配置Django服务器环境

    本环境是使用Ubuntu16.04+Django2.1.0+python3.6+uwsgi+nginx进行配置 1. 安装python3.6 Ubuntu16.04中原本安装的是python3.5,但 ...

  7. 实战SpringCloud响应式微服务系列教程(第二章)

    接上一篇:实战SpringCloud响应式微服务系列教程(第一章) 1.1.2背压 背压是响应式编程的核心概念,这一节也是我们了解响应式编程的重点. 1.背压的机制 在生产者/消费者模型中,我们意识到 ...

  8. 【iOS】UIAlertController 弹出框

    UIAlertView 虽然还能用,但已经废弃了.因此以后尽量用 UIAlertController.示例代码如下: UIAlertController *alert = [UIAlertContro ...

  9. 深入理解JVM-类加载器深入解析(3)

    深入理解JVM-类加载器深入解析(3) 获得ClassLoader的途径 获得当前类的ClassLoader clazz.getClassLoader() 获得当前线程上下文的ClassLoader ...

  10. C#:正则表达式类

     Regex r = new Regex("abc"); // 定义一个Regex对象实例(Regex r = new Regex("abc", RegexOp ...