zoukankan      html  css  js  c++  java
  • 8.4 学习日记

    8.4 学习日记

    KVM

    KVM 是 Linux 的一部分。Linux 也是 KVM 的一部分。Linux 有的,KVM 全都有。然而,KVM 的某些特点让它成为了企业的首选虚拟机监控程序。

    静态类:

    所谓静态,指以static关键字修饰的,包括类,方法,块,字段。

    静态类和非静态类之间的区别

    1.内部静态类不需要有指向外部类的引用。但非静态内部类需要持有对外部类的引用

    2.非静态内部类能够访问外部类的静态和非静态成员。静态类不能访问外部类的非静态成员。他只能访问外部类的静态成员

    3.一个非静态内部类不能脱离外部类实体被创建,一个非静态内部类可以访问外部类的数据和方法,因为他就在外部类里面

    4.其实就是静态类不用先创建外部类。可以静态类看做外部类的静态变量,使用就不要外部类实例;而非静态就必须先实例化。

    package com.example.mybatisplus.controller;
    
    /**
     * @ClassName: OutClass
     * @Description:
     * @Author: xf
     * @Date: 19.6.27 10:59
     * @Version: 1.0
     */
    public class OutClass {
    
        /**
         *  全局静态变量
         */
        private static final String msg = "i love java";
         // 创建静态类
        public static class staticInnerClass{
             public void showMsg() {
                 System.out.println("静态内部类展示信息:"+msg);
             }
    
        }
        // 创建非静态内部类
        public class InnerClass{
            public void disPlayMsg() {
                System.out.println("非静态内部类展示信息:"+msg);
            }
        }
    
        public static void main(String[] args) {
            // 创建静态内部类实例
            staticInnerClass sic = new OutClass.staticInnerClass();
            sic.showMsg();
    
            // 创建非静态内部类实例,需要先创建外部类的实例 OutClass().new
            InnerClass ic = new OutClass().new InnerClass();
            ic.disPlayMsg();
    
        }
    }
    

    匿名类两种

    1、与子类有关的匿名类

    2、与接口有关的匿名类

    // 子类有关的匿名类 // 接口相关的匿名类 则是把class Polygon替换为interface Polygon,同时方法不用进行实现

    class Polygon {
       public void display() {
          System.out.println("在 Polygon 类内部");
       }
    }
    
    class AnonymousDemo {
       public void createClass() {
    
          // 创建的匿名类继承了 Polygon 类
          Polygon p1 = new Polygon() {
             public void display() {
                System.out.println("在匿名类内部。");
             }
          };
          p1.display();
       }
    }
    
    class Main {
       public static void main(String[] args) {
           AnonymousDemo an = new AnonymousDemo();
           an.createClass();
       }
    }
    

    内部类

    在 Java 中,可以将一个类定义在另一个类里面或者一个方法里面,这样的类称为内部类。广泛意义上的内部类一般来说包括这四种:成员内部类、局部内部类、匿名内部类和静态内部类。下面就先来了解一下这四种内部类的用法。 1.成员内部类 成员内部类是最普通的内部类,它的定义为位于另一个类的内部,形如下面的形式:

    class Circle {
        double radius = 0;
         
        public Circle(double radius) {
            this.radius = radius;
        }
         
        class Draw {     //内部类
            public void drawSahpe() {
                System.out.println("drawshape");
            }
        }
    }
    

    这样看起来,类Draw像是类Circle的一个成员,Circle称为外部类。成员内部类可以无条件访问外部类的所有成员属性和成员方法(包括private成员和静态成员)。

    class Circle {
        private double radius = 0;
        public static int count =1;
        public Circle(double radius) {
            this.radius = radius;
        }
         
        class Draw {     //内部类
            public void drawSahpe() {
                System.out.println(radius);  //外部类的private成员
                System.out.println(count);   //外部类的静态成员
            }
        }
    }
    

    不过要注意的是,当成员内部类拥有和外部类同名的成员变量或者方法时,会发生隐藏现象,即默认情况下访问的是成员内部类的成员。如果要访问外部类的同名成员,需要以下面的形式进行访问:

    外部类.this.成员变量
    外部类.this.成员方法
    

    虽然成员内部类可以无条件地访问外部类的成员,而外部类想访问成员内部类的成员却不是这么随心所欲了。在外部类中如果要访问成员内部类的成员,必须先创建一个成员内部类的对象,再通过指向这个对象的引用来访问:

    class Circle {
        private double radius = 0;
     
        public Circle(double radius) {
            this.radius = radius;
            getDrawInstance().drawSahpe();   //必须先创建成员内部类的对象,再进行访问
        }
         
        private Draw getDrawInstance() {
            return new Draw();
        }
         
        class Draw {     //内部类
            public void drawSahpe() {
                System.out.println(radius);  //外部类的private成员
            }
        }
    }
    

    成员内部类是依附外部类而存在的,也就是说,如果要创建成员内部类的对象,前提是必须存在一个外部类的对象。创建成员内部类对象的一般方式如下:

    public class Test {
        public static void main(String[] args)  {
            //第一种方式:
            Outter outter = new Outter();
            Outter.Inner inner = outter.new Inner();  //必须通过Outter对象来创建
             
            //第二种方式:
            Outter.Inner inner1 = outter.getInnerInstance();
        }
    }
     
    class Outter {
        private Inner inner = null;
        public Outter() {
             
        }
         
        public Inner getInnerInstance() {
            if(inner == null)
                inner = new Inner();
            return inner;
        }
          
        class Inner {
            public Inner() {
                 
            }
        }
    }
    

    内部类可以拥有 private 访问权限、protected 访问权限、public 访问权限及包访问权限。比如上面的例子,如果成员内部类 Inner 用 private 修饰,则只能在外部类的内部访问,如果用 public 修饰,则任何地方都能访问;如果用 protected 修饰,则只能在同一个包下或者继承外部类的情况下访问;如果是默认访问权限,则只能在同一个包下访问。这一点和外部类有一点不一样,外部类只能被 public 和包访问两种权限修饰。我个人是这么理解的,由于成员内部类看起来像是外部类的一个成员,所以可以像类的成员一样拥有多种权限修饰。

    2.局部内部类 局部内部类是定义在一个方法或者一个作用域里面的类,它和成员内部类的区别在于局部内部类的访问仅限于方法内或者该作用域内。

    class People{
        public People() {
             
        }
    }
     
    class Man{
        public Man(){
             
        }
         
        public People getWoman(){
            class Woman extends People{   //局部内部类
                int age =0;
            }
            return new Woman();
        }
    } 
    

    注意: 局部内部类就像是方法里面的一个局部变量一样,是不能有 public、protected、private 以及 static 修饰符的。

    3.匿名内部类 上面已经介绍过了 分为关于子类的或者关于接口使用部分

    4.静态内部类 上面已介绍

    常见题目类型:https://www.runoob.com/w3cnote/java-inner-class-intro.html

    异常抛出:

    总结存在3中异常类

    1. Error
    2. Exception(非RuntimeException)
    3. RuntimeException

    注意事项:

    • Error一般用在永远不会出现的错误
    • RuntimeException一般用于表示由于程序设计漏洞产生的错误
    • Exception(非RuntimeException)表示流程类的错误类
    • 所以在我们的日常使用中可以使用Exception(非RuntimeException)的情况会居多

    一般的写法为: -w650 实现Exception重载的几种构造函数即可

    编写error与RuntimeException也差不多

    // 代码示例
    public class ExportException extends Exception {
     
        public ExportException() {
            super();
        }
     
        public ExportException(String message) {
            super(message);
        }
     
        public ExportException(String message, Throwable cause) {
            super(message, cause);
        }
     
        public ExportException(Throwable cause) {
            super(cause);
        }
     
        protected ExportException(String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) {
            super(message, cause, enableSuppression, writableStackTrace);
        }
    }
    

    Cloneable clone()

    如果对象implement Cloneable接口的话,需要覆盖clone方法(因为OBject类的clone方法是protected,需要覆盖为public)

    代码示例:

    那些年拷贝的对象
    /**
         * Test类重写clone方法
         */
        @Override
        protected Object clone() throws CloneNotSupportedException {
            
            Test cloned=(Test) super.clone();
            
            cloned.date=(Date) date.clone();
            
            return cloned;
        }
    
  • 相关阅读:
    嵌入式Linux的启动过程
    【转载】vim 中文帮助手册的安装
    面向对象之编写驱动程序--中断(linux系统、s3c6410开发板)
    【转】DBCC IND / DBCC PAGE
    【转】索引查询 sys.dm_db_index_physical_stats
    【tag】Enum.HasFlag 方法
    【tag】Tuple 类 使用介绍
    【fixed point】柯里化(currying) C#实现
    SqlDataAdapter 批量更新 DataTable
    sqlCacheDependency 使用
  • 原文地址:https://www.cnblogs.com/athony/p/13434092.html
Copyright © 2011-2022 走看看