黑马程序员之Java学习笔记17

网络编程:

1. read()方法和accept方法一样都是阻塞方法。

2.基于TCP的网络编程:

1)服务端:创建ServerSocket对象,监听指定端口-à调用accept方法,返回一个socket对象à通过socket对象获得输入输出流à后续的I/O操作à关闭流和socket

2)客户端:创建一个socket对象,指定IP和端口(这时服务端和客户端的两个socket就连接好了)通过socket对象获得输入输出流-à后续的I/O操作à关闭流和socket.

3.基于UDP的网络编程:就像写信一样,主要用到DatagramScoket类及该类的sendreceive方法和DatagramPacket类。DatagramPacket对象封装了要发送的数据信息,包括发送过来的IP地址和端口。

 

4.JVM中的类加载器(ClassLoader)

      1) JVM结束,程序肯定会结束。

      2) 类的静态变量i,在类的加载时期,其值为默认值(如:int类型的默认值为0,引用类型的默认值为null),然后才是初始化的值。

     3) 类加载的过程:加载à连接à初始化.

         加载:从硬盘中查找并加载类的二进制数据进内存,并创建唯一Class对象。

         连接:--验证:确保加载类的正确性。

              --准备:为类的静态变量分配内存,并赋上默认值。

              --解析:把类中的符号引用改为直接引用。

        初始化:为类的静态变量赋上正确的初始值。

  4)  只有JVM才能创建Class对象。

  5) java程序对类的使用方式有两种:主动使用,会导致类的初始化;被动使用,则不会。

6)主动使用类的六种方式:

   A.访问类的静态变量或对其赋值。

   B.调用类的静态方法。

   C.反射,如:Class.forName(“java.lang.String”)

   D.初始化一个类的子类

   E.创建类的实例

   Fjava虚拟机启动时被标明为启动类(含有main方法的类就是启动类)。

7       类的静态变量的初始化有两种方式:在声明中初始化,如:public static int I =10;在静态代码块中初始化static{  I =3}

 8     类的加载的最终结果是位于堆中的Class对象。Class对象封装了该类的数据结果,并向外提供了访问接口。

9) 类加载器的分类:

AJVM自带的类加载器:

根类加载器:使用C++编写的,java程序员无法获得该加载器。

扩展类加载器:使用java编写。

系统类加载器(应用加载器):使用java编写。

 

A. 自定义的类加载器:用户自定义的类加载器都是java.lang.ClassLoader(抽象类)类的子类。

 10每一个Class对象都包含一个定义该类的ClassLoader的引用。通过调用getClassLoader方法获得一个ClassLoader的引用。当该类由根类加载器(Bootstrap)加载,该方法会返回一个null

 11)         如果final的静态变量i在编译期间能确定(此时i就是常量),那么在用类名调用变量时,不会初始化类;如果不能确定i的值,那么在用类名调用变量时,会初始化类。

12)    java虚拟机在初始化一个类时,要求它的所有父类都被初始化(层层往上),但并不适用接口。

13同一个类加载器中,每个类都只能初始化一次,不能重复初始化。

14)同一个java文件中,含有main方法的Test类中的静态变量和静态代码块会首先初始化(相对于其他类中的静态变量和静态代码块)。

15)只有当程序访问的静态变量和静态方法确实定义在该类或该接口中,当访问变或调用时,才会去初始化该类或接口。

16调用ClassLoader类的loadClass方法加载一个类,并不是对类的主动使用,因此不会初始化该类。

17)类加载器的父亲委托机制(Parent Delegation):在委托机制中,除了JVM自带的根类加载器以外,其余的类加载器有且只有一个父加载器。当程序请求加载器loader加载某一个类时,loader会委托该加载器的父加载器parentLoader去加载。若父加载器parentLoader能加载,子加载器loader就不去加载,若父加载器parentLoader不能加载该类,子加载器才去加载该类。

18)各种加载器之间的父子关系:根类加载器-à扩展类加载器à系统类加载器(应用加载器)à自定义类加载器(自定义类加载器的默认父加载器是系统类加载器)。(箭头指向的为子)加载器之间的父子关系实际是值加载器对象之间的包装关系,(并非一定是继承关系)子加载器对象包装了父加载器对象。

19根类加载器只会加载jdk提供的类。如,java.lang.*等。

20          当自定义一个类加载器实例时,在使用ClassLoader()方法获得一个加载器时,getSystemClassLoader()返回的一个系统类加载器会作为该加载器的默认父加载器。

21使用父亲委托机制最重要的原因是出于安全因素考虑,它能提高软件系统的安全性。

22)如何创建自定义类加载器:只需要继承java.lang.ClassLoader类并重写它的findClass(String name)方法.该方法会根据name(类名的全称,包括包名)返回对应的Class对象引用。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值