资源描述
JavaSE期末总测试
注意:
直接将自己的答案编写在每一道试题的下面,代码要规范,最好使用不同背景加注,
提交试卷的时候文件的命名格式如:”姓名.doc”
一、简答题
1. 简述面向对象的特征有哪些方面?
三大特征:封装、继承、多态
1、 封装:在开发中,实体类我们一般都会封装起来,隐藏对象的属性和实现细节,仅对外提供公共访问方式。
1) 私有化属性
2) 根据需求设置set、get方法
3) 提供公共方法对其访问
2、 继承:
1) 父类的由来:多个类不断向上抽取共性内容而来的
2) 只支持单继承,但支持多重继承,即A继承B,B继承C,C继承D
3) 为什么不支持多继承,当两个父类中有相同的功能时,子类方法调用该功能时该运行哪一个呢?
4) 当类与类之间存在着所属关系时,才具备了继承的前提
5) 子类覆盖父类时,必须要保证子类方法的权限大于等于父类方法的权限
6) 覆盖时,要么都静态,要么都不静态
3、 多态:
1) 体现:父类的引用或者接口的引用指向了自己的子类对象,即父类可以调用子类中复写过的方法。// Animal a = new Cat();
2) 前提:必须要有关系,如继承、实现;通常会有覆盖操作
3) 弊端:当父类引用指向子类对象时,只能访问父类中含有的方法
2. 简述StringBuffer和StringBuilder的区别?(10分)
StringBuffer:字符串缓冲区,从JDK1.0开始的,是一个线程安全的存储字符容器。如果频繁修改字符串的内容,建议使用字符串缓冲类StringBuffer。
StringBuilder:字符串缓冲区,从JDK1.5开始的,非线程安全,但效率高。
单线程操作,使用StringBuilder效率高;多线程操作,使用StringBuffer安全。
3. 在main方法中的执行代码如下:
String s1 = "abc";
String s2 = "abc";
System.out.println(s1 == s2);
请写出以上代码的输出的结果,分析输出结果的原因。(10分)
打印:true
String对象可以直接使用字面量赋值,而且多个String对象指向同一个字面量时,在堆内存当中只有一个java对象。如果调用String构造函数给String类型的引用赋值,那么每调用一次构造函数,在堆内存当中就会生成一个string对象。所以,如果s1、s2都是同一个字面量赋值,那么无论是用==还是equals(),都返回true。如果s1、s2使用String构造函数生成对象,并且传入的字面量相等,那么用==返回false,用equals()返回true。
4.多线程有几种实现方法?同步有几种实现方法? (10分)
两大方法:extend Thread类、implements Runnable接口
1、继承Thread类,由子类腹泻run()方法
1) 自定义子类继承Thread类
2) 将让线程运行的代码存储到run()方法中
3) 通过创建Thread的子类对象,创建线程对象
4) 通过子类调用start()方法,开启线程
2、实现Runnable接口
1)自定义类实现Runnable接口
2)将让线程运行的代码存储到run()方法中
3)创建Thread类线程对象
4)创建自定义类对象,将自定义类对象作为实际参数传递给Thread类的构造函数(为了让线程对象明确要运行的run方法所属的对象)
5)调用Thread对象的start方法开启线程,并运行Runnable接口中的run方法
synchronized,wait 与notify 都可以实现同步
5. 列出Java你所知道的集合体系,并简述各自的特点.(10分)
集合:用于存储数据的容器
特点:集合用于存储对象;集合是可变长度的
集合与数组的区别:
1) 数组是固定长度的,集合是可变长度的
2) 数组可以存储基本数据类型,也可以存储引用数据类型;集合只能存储引用数据类型
3) 数组存储的元素是同一个类型的元素;集合存储的对象可以是不同数据类型的对象
单列集合:Collection,根接口
List:有序,元素有索引,元素可以重复
Set:无序,不可以存储重复元素,必须保证元素的唯一性
ArrayList:底层的数据结构是数组,线程不同步,非线程安全,查询速度快,增删慢;
LinkedList:底层的数据结构是链表,线程不同步,非线程安全,查询速度慢,增删快;
Vector:底层的数据结构是数组,线程同步,线程安全,查询、增删都非常慢
HashSet:底层是哈希表,线程不同步,非线程安全,无序、高效
LinkedHashSet:有序,HashSet的子类
TreeSet:底层的数据结构是二叉树,线程不同步,非线程安全,对Set集合中的元素排序
双列集合:Map,根接口
HashTable:底层是哈希表数据结构,线程同步,不可以存储null键、null值
HashMap:底层是哈希表数据结构,线程不同步,可以存null键、null值,替代了HashTable
TreeMap:底层是二叉树结构,可以对map集合中的键值进行指定顺序的排序
6.集合与数组的区别是什么呢?(10分)
1)集合是可变长度的,数组是固定长度的
2)集合只能存储对象的引用,数组既可以存储对象的引用又可以存储基本数据类型
3)集合可以存储不同数据类型的元素,数组只能存储相同数据类型的元素
7.Collection和Collections的区别?(10分)
Collection是java.util下的接口,是各种集合结构的父接口,继承于它的接口主要有Set、List,提供了一些关于集合的一些操作,如插入、删除、判断一个元素是否为其成员、遍历等操作。
Collections是java.util下的类,是集合的帮助类,提供一些静态方法,实现对集合的查找、排序、替换、线程安全化等操作。
8.HashSet是如何保证元素唯一性的。(10分)
HashSet底层数据结构是哈希表,不存入重复元素,线程不同步,无序、高效。
HashSet集合保证元素的唯一性,是通过元素的hashCode方法和equals方法完成的。当元素的hashCode值相同时,才判断元素的equals是否为true,如果为true,则视为相同元素,不存储;如果为false,则存储。如果hashCode值不同,则不判断equals,从而提高对象的比较速度。
9.简述ArrayList与Vector的区别,ArrayList与LinkedList的区别(10分)
ArrayList与Vector底层数据结构都是Object数组,ArrayList非线程安全;Vector线程安全,但查询、增删都非常慢。
ArrayList:底层数据结构是Object数组,线程不同步,非线程安全,查询快,增删慢
LinkedList:底层数据结构是链表,线程不同步,非线程安全,查询慢,增删快
如果我们需要保留存储顺序,并且保留重复元素的时候,使用List;如果查询比较多,则使用ArrayList;如果存取比较多,则使用LinkedList;如果要线程安全,则使用Vector。
二、 编程题(写出代码思路,伪代码)
1.使用TCP,模拟一下QQ的信息交流功能,客户端,服务端(10分)
package test;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import .ServerSocket;
import .Socket;
public class Test22 {
/*建立 tcp 的服务器
接受客户端的连接,传声一个Socket
获取到Socket的输入流对象
获取到Socket输出流的对象
获取键盘的输入流对象
读取客户端的数据
关闭资源
*/
public static void main(String[] args) throws IOException {
ServerSocket serverSocket = new ServerSocket(8088);
Socket socket =serverSocket.accept();
BufferedReader sReader = new BufferedReader(new InputStreamReader(socket.getInputStream()));
OutputStreamWriter sOut = new OutputStreamWriter(socket.getOutputStream());
BufferedReader keyReader = new BufferedReader(new InputStreamReader(System.in) );
String line = null;
while((line = sReader.readLine())!=null){
System.out.println("服务端接收到的信息:"+line);
System.out.println("请输入回送给客户端");
line=keyReader.readLine();
sOut.write(line+"\r\n");
sOut.flush();
}
serverSocket.close();
}
}
客户端类
package test;
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import .InetAddress;
import .Socket;
import .UnknownHostException;
public class Test22send {
public static void main(String[] args) throws IOException, IOException {
//建立tcp的客户端服务
//获取socket的输出对象
//获取socket的输入流对象
//获取键盘的输入流对象,读取数据
//不断的读取键盘录入数据,然后把数据写出
//flush刷一把
//...
Socket socket = new Socket(InetAddress.getLocalHost(),8088);
OutputStreamWriter sOut = new OutputStreamWriter(socket.getOutputStream());
BufferedReader sReader = new BufferedReader(new InputStreamReader(socket.getInputStream()));
BufferedReader keyReader = new BufferedReader(new InputStreamReader(System.in));
String line = null;
while((line = keyReader.readLine())!=null
){
sOut.write(line+"\r\n");
sOut.flush();
line = sReader.readLine();
System.out.print("服务器送回的数据是:"+line);
}
socket.close();
}
}
2. 编写一个方法实现拷贝任意文件的功能,要求效率最高。(10分)
package test;
import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.Scanner;
public class CopyFile {
public static void main(String[] args) throws IOException {
System.out.print("请输入要拷贝的文件的绝对路径");
Scanner s = new Scanner(System.in);
File inFile = new File(s.next());
File outFile = new File("E:\\CopyFile.jpg");
System.out.println("拷贝成功,拷贝的路径是E:\\CopyFile.jpg");
FileInputStream fileInputStream = new FileInputStream(inFile);
FileOutputStream fileOutputStream = new FileOutputStream(outFile);
BufferedInputStream bufferedInputStream = new BufferedInputStream(fileInputStream);
BufferedOutputStream bufferedOutputStream = new BufferedOutputStream(fileOutputStream);
int content = 0;
while((content = bufferedInputStream.read())!=-1){
bufferedOutputStream.write(content);
}
bufferedInputStream.close();
bufferedOutputStream.close();
}
}
三、 课外扩展题(课后的时间做)作为课后扩展题不计入总分
1. 定义一个ArrayList集合,在类加载时添加10本书,书籍具有书名、作者、价格三个属性,在main函数中通过键盘录入一个书名时,查询出该书籍的详细信息。
展开阅读全文