Java软件开发工程师笔试题
  下面CN人才网小编为大家带来的是Java软件开发工程师笔试题,希望对大家有所帮助~
  一、选择题(本大题 20 小题,每小题2分.共40分)。
  1.在JAVA中,如果父类中某些方法不包含任何逻辑,并且需要由子类重写.应该使用( )关键字来声明父类的这些方法:
  A) final B) static C) abstract D) void
  2.在JAVA中,已定义两个接口B和C,要定义一个实现这两个接口的类,以下语句正确的是( )。
  A) interface A extend B,C B) interface A implements B,C
  C) class A implements B,C D) class A implements B, implements C
  3.在JAVA接口中可以定义( )。
  A) 静态方法 B) 常量 C) 构造方法 D) 抽象方法
  4.假设A有构造方法A (int a),则在类A的其他构造方法中调用该构造方法和语句格式应为( )。
  A) A(X) B) this.A(x) C) this(x) D) super(x)
  5.设 x = 1 ,y = 2 , z = 3, 则表达式 y+=z--/++x 的值是( )。
  A) 3 B) 3.5 C) 4 D) 5
  6.下列关于继承的说法哪个正确?( )。
  A)子类只继承父类public方法和属性:
  B)子类继承父类的非私有属性和方法:
  C)子类继承父类的方法,而不继承父类的属性:
  D) 子类将继承的所有的属性和方法.
  7.在java中.在使用JDBC时。对于多次调用同一条SQL语句的情况, 使用( )通常会提高效。
  A) Statement B) CallableStatement
  C) PreparedStatement D) PrarmeterStatement
  8.下列不能控制一个Servlet的生命周期方的法是:
  A) service B) destroy C) doPost D) init
  9.能够给一个byte型变量赋值的范围是( )。
  A) 0~65535 B) (-128)~127
  C)(-32, 768)~32, 767 D) (-256)~255
  10.java语言中int类型数据占用多少位?( )。
  A) 32 B) 64 C) 16 D) 20
  11. ServletContext对象是如何创建的?( )。
  A) 由 Servlet容器创建,对于每个HTTP请求.Servlet容器都会创建 一个ServletContext对象
  B)由JavaWeb 应用本身为自己创建一个ServletContext对象
  C)由Servlet容器创建,对于每个JaveWeb应用,在启动时,Servlet容器都会创建一个ServletContext对象
  12.在JSP中不能在不同用户之间共享数据的方法是( )。
  A) 通过cookie B) 利用文件系统
  C) 利用数据库 D) 通过ServletContext对象
  13.以下哪个不是Collection的子接口?( )。
  A) List B) Set C) Map D) SortedSet
  14. 下面正确的创建 Socket 的语句是( )。
  A) Socket a = new Soeket(80):
  B) Socket b = new Socket("130. 3. 4. 5", 80):
  C) ServerSocket c = new Socket(80)
  D) ServerSocket d = new Socket ("130. 3. 4, 5", 80)
  15.下面的说法正确的是( )。
  A)带有页作用域的对象在一个web应用程序的每个JSP中都存在.
  B)指令指定与一个特定的JSP 请求不相关的全局信息。
  C)当JSP容器遇到开始定制标签和结束定制标签时,分别调用 doInitBody方法和doAfterBody方法。
  D) 动作只在翻译时处理一次。
  16.为了区分重载多态中同名的不同方法,要求:( )。
  A)参数名不同 B) 采用不同的形式参数列表
  C)返回值类型不同 D) 选项A, B, C都对
  17.下面是有关子类调用父类构造函数的描述正确的是:( )。
  A)子类定义了自己的构造函数.就不会调用父类的构造函数
  B)子类必须通过Super关键字调用父类有参数的构造函数
  C)如果子类的构造没有通过super调用父类构造函数,那么子类会 先调用子类自己的构造函数,再调用父类不含参数的构造函数。
  D)创建子类的对象时,先调用子类自己的构造函数,然后调用父 类的构造函数
  18.在Java中,负责对字节代码解释执行的是( )。
  A) 垃圾回收器 B) 虚拟机 C) 编译器 D) 多线程机制
  19.一个java程序运行从上到下的环境次序是( )。
  A) 操作系统、Java程序、jre/jvm、硬件
  B) jre/jvm、Java程序、硬件、操作系统
java常见笔试题  C) java程序、jre/jvm、操作系统、硬件
  D) java程序、操作系统、jre/jvm、硬件
  20.对于从Employee表中选择记录的以下代码片段,识别其遗漏的代码行。( ) Connection con = null:
  Class. forName("sun.jdbc.odbc.JdbcOdbcDriver"):
  Connection("jdbc:odbc:ss" , "sa" , "");
  ResultSet uteQuery("select * from Employee");
  A) Statement stat=createStatement();
  B) Statement ateStatement ();
汉字十六进制编码转换  C) PreparedStatement ateStatement():
  D) PreparedStatement stat=createPreparedStatement();
  二、问答题(本大题6小题,共40分)。
平行宇宙电影  1.请说出 ArrayList , Vector , LinkedList 的存储性能和特性。(6分)
  2.什么是单例模式(Singleton) ? 请在下面写出一个单例模式类,并支持多线程调用。(6分)
  3.请描述一下JVM加载class文件的原理机制?(6分)
  4.请谈谈对SQL注入的理解,请给出你知道的防止SQL注入的方法。(6分)
  5.请谈谈对hibernate的理解,并简要叙述Hibernate的一级缓存和二级缓存(8分)。
  6.请写出你知道的排序方法,并使用Java语言写出其中一种。(8分)
  三、简答题(参考答案)
  1. ArrayList和Vector都是使用数组方式存储数据,此数组元素数大于实际存储的数据以便增加和插入元素,它们都允许直接按序号索引元素,但是插入元素要涉及数组元素移动等内存操作,所以索引数据快而插入数据慢,Vector由于使用了synchronized方法(线程安全),
通常性能上较ArrayList差,而LinkedList使用双向链表实现存储,按序号索引数据需要进行前向或后向遍历,但是插入数据时只需要记录本项的前后项即可,所以插入速度较快。
  2. 创建某类对象时,无论创建多少次该类对象只有一份在内存中,这就是单例模式。支持多线程调用,考虑线程安全,只需要加锁即可。
  public class Singleton{
  private static Singleton instance = null;
  private Singleton(){}
  private static synchronized void syncInit(){
  if(instance == null){
  instance = new Singleton();
  }
  }
  public static Singleton getInstance(){
  if(instance == null){
  syncInit();
  }
  return instance;
  }
  }
  3. JVM中类的装载是由ClassLoader和它的子类来实现的,Java ClassLoader是一个重要的Java运行时系统组件。它负责在运行时查和装入类文件的类。
  4.解决办法:a. 利用JavaScript,在客户端进行校验。
  b.程序判断 c.使用PreparedStatement连接数据库。(参数化) d.利用框架技术
  5. Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序使用,也可以在Servlet/JSP的Web应用中使用。
  一级缓存就是Session级别的缓存,一个Session做了一个查询操作,它会把这个操作的结果放在一级缓存中,如果短时间内这个
  session(一定要同一个session)又做了同一个操作,那么hibernate直接从一级缓存中拿,
而不会再去连数据库,取数据;
  二级缓存就是SessionFactory级别的缓存,顾名思义,就是查询的时候会把查询结果缓存到二级缓存中,如果同一个sessionFactory
  创建的某个session执行了相同的操作,hibernate就会从二级缓存中拿结果,而不会再去连接数据库;
  6.插入排序、希尔排序、冒泡排序、快速排序、直接排序、归并排序 下面以快速排序为例:
  1. public class quickSort {
屏下光线传感器  2.
  3. inta[]={49,38,65,97,76,13,27,49,78,34,12,64,5,4,62,99,98,54,56,17,18,23,34
  ,15,35,25,53,51};
  4. public quickSort(){
  5. quick(a);
  6. for(int i=0;i
  7. System.out.println(a[i]);
  8. }
  9. }
  10. public int getMiddle(int[] list, int low, int high) {
  11. int tmp =list[low]; //数组的第一个作为中轴
  12. while (low   13. while (low = tmp) {
  14. high--;matlab2012下载
  15. }
  16.
  17. list[low] =list[high]; //比中轴小的记录移到低端
  18. while (low   19. low++;
  20. }
  21.
  22. list[high] =list[low]; //比中轴大的记录移到高端
  23. }
  24. list[low] = tmp; //中轴记录到尾
  25. return low; //返回中轴的位置
  26. }
  27.
  28. public void _quickSort(int[] list, int low, int high) {
  29. if (low   30. int middle =getMiddle(list, low, high); //将list 数组进行一分为二
  31. _quickSort(list, low, middle - 1); //对低字表进行递归排序
  32. _quickSort(list,middle + 1, high); //对高字表进行递归排序
  33. }
  34. }
  35.
  36. public void quick(int[] a2) {
  37. if (a2.length > 0) { //查看数组是否为空
  38. _quickSort(a2,0, a2.length - 1);
  39. }
  40. }
噼哩噼哩2  41. }

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。