zoukankan      html  css  js  c++  java
  • Java 收集的代码 transient

    public class Main {
        public static void main(String[] args) {
            ((NULL)null).haha();
        }
    }
    
     class NULL {
        public static void haha(){
            System.out.println("haha");
        }
    }

    结果:

    haha

    输出为haha,因为null值可以强制转换为任何java类类型,(String)null也是合法的。但null强制转换后是无效对象,其返回值还是为null,而static方法的调用是和类名绑定的,不借助对象进行访问所以能正确输出。反过来,没有static修饰就只能用对象进行访问,使用null调用对象肯定会报空指针错了。这里和C++很类似。

    如果haha方法不是静态方法,那么编译器报错

    Exception in thread "main" java.lang.NullPointerException

    ======================================================================

    public class Main {
        public static void main(String[] args) {
            System.out.println("-------main start-------");
            new HelloB();
            new HelloB();
            System.out.println("-------main end-------");
        }
    }
    
    class HelloA {
    
        public HelloA() {
            System.out.println("HelloA");
        }
    
        { System.out.println("I'm A class"); }
        { System.out.println("I'm AAA class"); }
        static { System.out.println("static A"); }
    
    }
    
    class HelloB extends HelloA {
        public HelloB() {
            System.out.println("HelloB");
        }
    
        { System.out.println("I'm B class"); }
        { System.out.println("I'm BBB class"); }
        static { System.out.println("static B"); }
    }

    结果:

    -------main start-------
    static A
    static B
    I'm A class
    I'm AAA class
    HelloA
    I'm B class
    I'm BBB class
    HelloB
    I'm A class
    I'm AAA class
    HelloA
    I'm B class
    I'm BBB class
    HelloB
    -------main end-------

    考查静态语句块、构造语句块(就是只有大括号的那块)以及构造函数的执行顺序。

    对象的初始化顺序:(1)类加载之后,按从上到下(从父类到子类)执行被static修饰的语句;

                             (2)如果有语句new了自身的对象,将从上到下执行构造代码块、构造器(两者可以说绑定在一起)。

    =========================================================================================

    public class Main {
        public static void main(String[] args) {
            getValue();
        }
    
        public static void getValue() {
            char x = 'B';
            switch (x){
                case 'A': System.out.printf("A");
                case 'B': System.out.printf("B");
                case 'C': System.out.printf("C");
                default:  System.out.printf("D");
            }
        }
    }

    结果:

    BCD
    View Code

    case后面的常量表达式实际上只起语句标号作用,而不起条件判断作用,即"只是开始执行处的入口标号".

    因此,一旦与switch后面圆括号中表达式的值匹配,就从此标号处开始执行,而且执行完一个case后面的语句后,若没遇到break语句,就自动进入下一个case继续执行,而不在判断是否与之匹配,直到遇到break语句才停止执行。

    =====================================================================

    java 序列化

    代码:

    public class Main {
        public static void main(String[] args) {
            User user = new User();
            user.setUsername("Alexia");
            user.setPasswd("123456");
            user.sex="female";
            System.out.println("read before Serializable: ");
            System.out.println("username: " + user.getUsername());
            System.out.println("password: " + user.getPasswd());
            System.out.println("sex: " + user.sex);
            try {
                ObjectOutputStream os = new ObjectOutputStream(
                        new FileOutputStream("C:/user.txt"));
                os.writeObject(user); // 将User对象写进文件
                os.flush();
                os.close();
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
            try {
                ObjectInputStream is = new ObjectInputStream(new FileInputStream(
                        "C:/user.txt"));
                user = (User) is.readObject(); // 从流中读取User的数据
                is.close();
    
                System.out.println("
    read after Serializable: ");
                System.out.println("username: " + user.getUsername());
                System.out.println("password: " + user.getPasswd());
                System.out.println("sex: " + user.sex);
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            } catch (ClassNotFoundException e) {
                e.printStackTrace();
            }
        }
    
    }
    class Person {
        private String city="shanghai";
        public String sex="male";
    }
    
    class User extends Person implements Serializable {
        private static final long serialVersionUID = 8294180014912103005L;
    
        private String username;
        private transient String passwd;
    
        public String getUsername() {
            return username;
        }
    
        public void setUsername(String username) {
            this.username = username;
        }
    
        public String getPasswd() {
            return passwd;
        }
    
        public void setPasswd(String passwd) {
            this.passwd = passwd;
        }
    }

    结果:

    read before Serializable: 
    username: Alexia
    password: 123456
    sex: female
    
    read after Serializable: 
    username: Alexia
    password: null
    sex: male
    View Code

    1)一旦变量被transient修饰,变量将不再是对象持久化的一部分,该变量内容在序列化后无法获得访问。

    2)transient关键字只能修饰变量,而不能修饰方法和类。注意,本地变量是不能被transient关键字修饰的。变量如果是用户自定义类变量,则该类需要实现Serializable接口。

    3)被transient关键字修饰的变量不再能被序列化,一个静态变量不管是否被transient修饰,均不能被序列化

    可以发现sex属性没有被序列化,这是因为父类没有继承Serializable接口,如果继承接口就可以序列化。

    ===================================================================================

    public class Main {
        public static void main(String[] args) {
            System.out.println("X = " + A.X + ", Y = " + B.Y);
            //System.out.println("Y = " + B.Y + ", X = " + A.X);
        }
    }
    
    class A {
        public static int X;
    
        static {
            X = B.Y + 1;
        }
    }
    
    class B {
        public static int Y = A.X + 1;
        static {
        }
    }

    结果:

    X = 2, Y = 1
    View Code

    首先加载类A,然后调用B.Y,加载类B,调用A.X,此时A.X为0

    可以取消注释再运行试试。

    ============================================================

    http://www.cnblogs.com/lanxuezaipiao/p/3369962.html

    http://www.cnblogs.com/lanxuezaipiao/p/3371224.html

    http://www.cnblogs.com/lanxuezaipiao/p/4170157.html

  • 相关阅读:
    JSON学习笔记
    Java面试题之对static的理解
    【知了堂学习笔记】java基础知识之继承
    【知了堂学习笔记】多态基本知识
    Final关键字
    子父类构造函数特点
    原来学编程这么简单,如何理解程序的本质(今天听了【遇见狂神说】发布的《从HelloWorld到程序本质的思考》这个视频,有了自己的一些感悟,在这里和大家做一个分享)
    浅谈c3p0连接池和dbutils工具类的使用
    Mysql数据库重要知识点
    Express安装与调试
  • 原文地址:https://www.cnblogs.com/hongdada/p/5826288.html
Copyright © 2011-2022 走看看