zoukankan      html  css  js  c++  java
  • 高级特性复习题

    1. 基本数据类型和包装类

    1)八个基本数据类型的包装类

    基本数据类型   包装类

    byte        Byte

    boolean     Boolean

    short       Short

    char        Character

    int         Integer

    long        Long

    float       Float

    double      Double

    2)为什么为基本类型引入包装类

    基本数据类型有方便之处,简单、高效。

    但是Java中的基本数据类型却是不面向对象的(没有属性、方法),这在实际使用时存在很多的不便(比如集合的元素只能是Object)。

    为了解决这个不足,在设计类时为每个基本数据类型设计了一个对应的类进行包装,这样八个和基本数据类型对应的类统称为包装类(Wrapper Class)。

    3) 包装类和基本数据类型之间的转换

    包装类------ wrapperInstance.xxxValue() ----------->基本数据类型

    包装类<-----new WrapperClass(primitive) new WrapperClass(string)------基本数据类型

    4)自动装箱和自动拆箱

    JDK1.5提供了自动装箱(autoboxing)和自动拆箱(autounboxing)功能, 从而实现了包装类和基本数据类型之间的自动转换

    5)、包装类还可以实现基本类型变量和字符串之间的转换

    基本类型变量------------String.valueof()------------>字符串

    基本类型变量<------------WrapperClass.parseXxx(string)------------字符串

    2、Integer与int的区别

    int是java提供的8种原始数据类型之一。Java为每个原始类型提供了封装类,Integer是java为int提供的封装类。int的默认值为0,而Integer的默认值为null,即Integer可以区分出未赋值和值为0的区别,int则无法表达出未赋值的情况,例如,要想表达出没有参加考试和考试成绩为0的区别,则只能使用Integer。在JSP开发中,Integer的默认为null,所以用el表达式在文本框中显示时,值为空白字符串,而int默认的默认值为0,所以用el表达式在文本框中显示时,结果为0,所以,int不适合作为web层的表单数据的类型。

    在Hibernate中,如果将OID定义为Integer类型,那么Hibernate就可以根据其值是否为null而判断一个对象是否是临时的,如果将OID定义为了int类型,还需要在hbm映射文件中设置其unsaved-value属性为0。

    另外,Integer提供了多个与整数相关的操作方法,例如,将一个字符串转换成整数,Integer中还定义了表示整数的最大值和最小值的常量。

    3. Java集合体系结构(List、Set、Collection、Map的区别和联系)

     

     

    Collection 接口存储一组不唯一,无序的对象

    List 接口存储一组不唯一,有序(插入顺序)的对象

    Set 接口存储一组唯一,无序的对象

    Map接口存储一组键值对象,提供key到value的映射。Key无序,唯一。value不要求有序,允许重复。(如果只使用key存储,而不使用value,那就是Set)

    4. Vector和ArrayList、ArrayList和LinkedList的区别和联系

    VectorArrayList的区别和联系

    实现原理相同,功能相同,都是长度可变的数组结构,很多情况下可以互用

    两者的主要区别如下

    1. Vector是早期JDK接口,ArrayList是替代Vector的新接口
    2. Vector线程安全,ArrayList重速度轻安全,线程非安全
    3. 长度需增长时,Vector默认增长一倍,ArrayList增长50%

     

    ArrayListLinkedList的区别和联系

    ArrayList实现了长度可变的数组,在内存中分配连续空间。遍历元素和随机访问元素的效率比较高;

     

    LinkedList采用链表存储方式。插入、删除元素时效率比较高

     

    5. HashMap和Hashtable的区别和联系

    实现原理相同,功能相同,底层都是哈希表结构,查询速度快,在很多情况下可以互用

    两者的主要区别如下

    1. Hashtable是早期JDK提供的接口,HashMap是新版JDK提供的接口
    2. Hashtable继承Dictionary类,HashMap实现Map接口
    3. Hashtable线程安全,HashMap线程非安全
    4. Hashtable不允许null值,HashMap允许null值

    6. HashSet的使用和原理(hashCode()和equals())

    1)      哈希表的查询速度特别快,时间复杂度为O(1)。

    2)      HashMap、Hashtable、HashSet这些集合采用的是哈希表结构,需要用到hashCode哈希码,hashCode是一个整数值。

    3)      系统类已经覆盖了hashCode方法 自定义类如果要放入hash类集合,必须重写hashcode。如果不重写,调用的是Object的hashcode,而Object的hashCode实际上是地址。

    4)      向哈希表中添加数据的原理:当向集合Set中增加对象时,首先集合计算要增加对象的hashCode码,根据该值来得到一个位置用来存放当前对象,如在该位置没有一个对象存在的话,那么集合Set认为该对象在集合中不存在,直接增加进去。如果在该位置有一个对象存在的话,接着将准备增加到集合中的对象与该位置上的对象进行equals方法比较,如果该equals方法返回false,那么集合认为集合中不存在该对象,在进行一次散列,将该对象放到散列后计算出的新地址里。如果equals方法返回true,那么集合认为集合中已经存在该对象了,不会再将该对象增加到集合中了。

    5)      在哈希表中判断两个元素是否重复要使用到hashCode()和equals()。hashCode决定数据在表中的存储位置,而equals判断是否存在相同数据。

    6)   Y=K(X) :K是函数,X是哈希码,Y是地址

    7. TreeSet的原理和使用(Comparable和comparator)

    1、TreeSet中的元素不允许重复,但是有序

    2、TreeSet采用树结构存储数据,存入元素时需要和树中元素进行对比,需要指定比较策略。可以通过Comparable和Comparator来指定比较策略。

    3、实现了Comparable的系统类可以顺利存入TreeSet。自定义类可以实现Comparable接口来指定比较策略。

    4、可创建Comparator接口实现类来指定比较策略,并通过TreeSet构造方法参数传入。这种方式尤其对系统类非常适用。

    8. 集合和数组的比较(为什么引入集合)

    数组不是面向对象的,存在明显的缺陷,集合完全弥补了数组的一些缺点,比数组更灵活更实用,可大大提高软件的开发效率而且不同的集合框架类可适用于不同场合。具体如下:

    1:数组的效率高于集合类.

    2:数组能存放基本数据类型和对象,而集合类中只能放对象。

    3: 数组容量固定且无法动态改变,集合类容量动态改变。

    4:数组无法判断其中实际存有多少元素,length只告诉了array的容量。

    5:集合有多种实现方式和不同的适用场合,而不像数组仅采用顺序表方式。

    6:集合以类的形式存在,具有封装、继承、多态等类的特性,通过简单的方法和属性调用即可实现各种复杂操作,大大提高软件的开发效率。

    9. Collection和Collections的区别

    Collection是Java提供的集合接口,存储一组不唯一,无序的对象。它有两个子接口List和Set。

    Java中还有一个Collections类,专门用来操作集合类 ,它提供一系列静态方法实现对各种集合的搜索、排序、线程安全化等操作。

    10.进程和线程有什么联系和区别?

     

     

    1.定义:

    1)         进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动,是系统进行资源分配和调度的一个独立单位。

    2)         线程是进程的一个实体,是CPU调度和分派的基本单位,他是比进程更小的能独立运行的基本单位,线程自己基本上不拥有系统资源,只拥有一点在运行中必不可少的资源(如程序计数器,一组寄存器和栈),一个线程可以创建和撤销另一个线程;

    2.进程和线程的关系:

    (1)一个线程只能属于一个进程,而一个进程可以有多个线程,但至少有一个线程。

    (2)资源分配给进程,同一进程的所有线程共享该进程的所有资源。

    (3)线程在执行过程中,需要协作同步。不同进程的线程间要利用消息通信的办法实现同步。

    (4)处理机分给线程,即真正在处理机上运行的是线程。

    (5)线程是指进程内的一个执行单元,也是进程内的可调度实体。

    3.线程与进程的区别:

    (1)调度:线程作为调度和分配的基本单位,进程作为拥有资源的基本单位。

    (2)并发性:不仅进程之间可以并发执行,同一个进程的多个线程之间也可以并发执行。

    (3)拥有资源:进程是拥有资源的一个独立单位,线程不拥有系统资源,但可以访问隶属于进程的资源。

    (4)系统开销:在创建或撤销进程的时候,由于系统都要为之分配和回收资源,导致系统的明显大于创建或撤销线程时的开销。但进程有独立的地址空间,进程崩溃后,在保护模式下不会对其他的进程产生影响,而线程只是一个进程中的不同的执行路径。线程有自己的堆栈和局部变量,但线程之间没有单独的地址空间,一个线程死掉就等于整个进程死掉,所以多进程的程序要比多线程的程序健壮,但是在进程切换时,耗费的资源较大,效率要差些

    11.创建线程的两种方式分别是什么?

    方式1:继承Java.lang.Thread类,并覆盖run() 方法。优势:编写简单;劣势:无法继承其它父类

    public class ThreadDemo1 {

             public static void main(String args[]) {

                       MyThread1 t = new MyThread1();

                       t.start();

                       while (true) {

                                System.out.println("兔子领先了,别骄傲");

                       }

             }

    }

    class MyThread1 extends Thread {

             public void run() {

                       while (true) {

                                System.out.println("乌龟领先了,加油");

                       }

             }

    }

    方式2:实现Java.lang.Runnable接口,并实现run()方法。优势:可继承其它类,多线程可共享同一个Thread对象;劣势:编程方式稍微复杂,如需访问当前线程,需调用Thread.currentThread()方法

    public class ThreadDemo2 {

             public static void main(String args[]) {

                       MyThread2 mt = new MyThread2();

                       Thread t = new Thread(mt);

                       t.start();

                       while (true) {

                                System.out.println("兔子领先了,加油");

                       }

             }

    }

    class MyThread2 implements Runnable {

             public void run() {

                       while (true) {

                                System.out.println("乌龟超过了,再接再厉");

                       }

             }

    }

    12.如何实现线程同步?

    当多个线程访问同一个数据时,容易出现线程安全问题,需要某种方式来确保资源在某一时刻只被一个线程使用。需要让线程同步,保证数据安全

    线程同步的实现方案:同步代码块和同步方法,均需要使用synchronized关键字

    同步代码块:public void makeWithdrawal(int amt) {

                                          synchronized (acct) {    }

    }

    同步方法:public synchronized void makeWithdrawal(int amt) {       }

    线程同步的好处:解决了线程安全问题

    线程同步的缺点:性能下降,可能会带来死锁

    13. Java中实现线程通信的三个方法的作用是什么?

    Java提供了3个方法解决线程之间的通信问题,均是java.lang.Object类的方法,都只能在同步方法或者同步代码块中使用,否则会抛出异常。

    方法名

    作  用

    final void wait()

    表示线程一直等待,直到其它线程通知

    void wait(long timeout)

    线程等待指定毫秒参数的时间

    final void wait(long timeout,int nanos)

    线程等待指定毫秒、微妙的时间

    final void notify()

    唤醒一个处于等待状态的线程。注意的是在调用此方法的时候,并不能确切的唤醒某一个等待状态的线程,而是由JVM确定唤醒哪个线程,而且不是按优先级。

    final void notifyAll()

    唤醒同一个对象上所有调用wait()方法的线程,注意并不是给所有唤醒线程一个对象的锁,而是让它们竞争

    14.什么是java序列化,如何实现java序列化?

    我们有时候将一个java对象变成字节流的形式传出去或者从一个字节流中恢复成一个java对象,例如,要将java对象存储到硬盘或者传送给网络上的其他计算机,这个过程我们可以自己写代码去把一个java对象变成某个格式的字节流再传输,但是,jre本身就提供了这种支持,我们可以调用OutputStream的writeObject方法来做,如果要让java 帮我们做,要被传输的对象必须实现serializable接口,这样,javac编译时就会进行特殊处理,编译的类才可以被writeObject方法操作,这就是所谓的序列化。需要被序列化的类必须实现Serializable接口,该接口是一个mini接口,其中没有需要实现的方法,implements Serializable只是为了标注该对象是可被序列化的。

    例如,在web开发中,如果对象被保存在了Session中,tomcat在重启时要把Session对象序列化到硬盘,这个对象就必须实现Serializable接口。如果对象要经过分布式系统进行网络传输或通过rmi等远程调用,这就需要在网络上传输对象,被传输的对象就必须实现Serializable接口。

    15.介绍OSI七层模型和TCP/IP模型

    1. OSI(Open System Interconnection),开放式系统互联参考模型 。是一个逻辑上的定义,一个规范,它把网络协议从逻辑上分为了7层。每一层都有相关、相对应的物理设备,比如常规的路由器是三层交换设备,常规的交换机是二层交换设备。OSI七层模型是一种框架性的设计方法,建立七层模型的主要目的是为解决异种网络互连时所遇到的兼容性问题,其最主要的功能就是帮助不同类型的主机实现数据传输。它的最大优点是将服务、接口和协议这三个概念明确地区分开来,通过七个层次化的结构模型使不同的系统不同的网络之间实现可靠的通讯。
    2. TCP/IP协议是Internet最基本的协议、Internet国际互联网络的基础,主要由网络层的IP协议和传输层的TCP协议组成。TCP/IP 定义了电子设备如何连入因特网,以及数据如何在它们之间传输的标准。协议采用了4层的层级结构,每一层都呼叫它的下一层所提供的协议来完成自己的需求。
    3. ISO制定的OSI参考模型的过于庞大、复杂招致了许多批评。伴随着互联网的流行,其本身所采用的TCP/IP协议栈获得了更为广泛的应用和认可。在TCP/IP参考模型中,去掉了OSI参考模型中的会话层和表示层(这两层的功能被合并到应用层实现)。同时将OSI参考模型中的数据链路层和物理层合并为主机到网络层。

     

    16. TCP协议和UDP协议的比较

    TCP和UDP是TCP/IP协议栈中传输层的两个协议,它们使用IP路由功能把数据包发送到目的地,从而为应用程序及应用层协议(包括:HTTP、SMTP、SNMP、FTP和Telnet)提供网络服务。TCP传输原理类似电话通信系统,而UDP传输原理类似电报通信系统。具体区别如下:

    1. TCP是面向连接的传输。UDP是无连接的传输
    2. TCP有流量控制、拥塞控制,检验数据数据按序到达,而UDP则相反。
    3. TCP的路由选择只发生在建立连接的时候,而UDP的每个报文都要进行路由选择
    4. TCP是可靠性传输,他的可靠性是由超时重发机制实现的,而UDP则是不可靠传输
    5. UDP因为少了很多控制信息,所以传输速度比TCP速度快
    6. TCP适合用于传输大量数据,UDP适合用于传输小量数据

    17.什么是Socket编程;简述基于TCP协议的Socket编程的主要步骤

    什么是Socket编程

    所谓socket通常也称作"套接字",用于描述IP地址和端口,是一个通信链的句柄。应用程序通常通过"套接字"向网络发出请求或者应答网络请求。        

    Socket套接字用于在主机和Internet之间建立可靠的、双向的、持续的、点对点的流式连接。一个套接字可以用来建立Java的输入输出系统到其他的驻留在本地机或Internet上的任何机器的程序的连接。应用程序通过Socket向网络发出请求或者应答网络请求,Socket隐藏了数据流传输中的复杂性。

             可以把Socket比作是一个港口码头,应用程序只要将数据交给Socket,就算完成了数据的发送,具体细节由Socket来完成,细节不必了解。同理,对于接收方,应用程序也要创建一个码头,等待数据的到达,并获取数据。

             Java分别为TCP和UDP 两种通信协议提供了相应的Socket编程类,这些类存放在java.net包中,与TCP对应的是服务器的ServerSocket和客户端的Socket,与UDP对应的是DatagramSocket。     

     

    基于TCP协议的Socket编程的主要步骤

     

  • 相关阅读:
    看云学习文档列表
    linux&&ubutun 21.06使用查询资料
    element-admin 查询资料笔记
    tp6 composer install 报Your requirements could not be resolved to an installable set of packages。
    centos 7 install npm
    centos 7 dev
    解決npm run dev 报: 'webpack-dev-server' 不是内部或外部命令,也不是可运行的程序 或批处理文件 错误
    解決vue-cli · Failed to download repo vuejs-templates/webpack: tunneling socket could not be established, cause=getaddrinfo ENOTFOUND 10809报错问题
    Linux创建命令快捷方式
    JS 闭包写法
  • 原文地址:https://www.cnblogs.com/xiaoxiao1016/p/9895489.html
Copyright © 2011-2022 走看看