JAVA基础部分-选择题(单选)1.在Java语言中,字符串“Java程序员”在内存中所占用的字节数是:()。
A.10B.7C.13D.142. (单选)下列表达式中,可以得到精确结果的是()。
A.double d1 = 3.0 - 2.6;B.double d4 = 2.5 * 1.5;C.double d2 = 30/300;D.double d3 = 1/2 + 0.5;3.(多选)所谓“水仙花”数是一个整数等于各位数字立方的和,例如:153 = 111+555+333,下面的程序用于输出2~1000内的水仙花数:下列选项中,空白处可以填入的代码是:()。
A.int s = 0, n1 = n; while (n1 > 0) { int t = n1 % 10; s += t * t * t; n1 /= 10; }B.int s = 0, n1 = n; while (n1 > 0) { int t = n1 / 10; s+= t * t * t; n1 %= 10; }C.int s = 0; for(int n1 = n; n1>0; n1 /= 10) { int t = n1%10; s += t * t * t; }D.int s = 0; for(int n1 = n; n1>0; n1 %= 10) { int t = n1 / 10; s += t * t * t; }4.下列语句序列执行后,k 的值是 ( )A.60B.5C.0D.545.设 a = 8,则表达式 a >>> 2 的值是:(无符号右移动)( )A.1B.2C.3D.46.下列程序在程序中插入下列哪一行代码可以编译通过: A static void doSomething(int[] args){}B static void doSomething(int... args){}C static coid doSomething(int...args,int x){}D static void doSomething(int x,int...args){}简答题1.现有一个长度为20的数组,数组内的数字0-9之间的任意数字,统计出数组中每个元素出现的次数?现有一个字符串"fdasafdasfdasa",现统计出子串"as"出现的次数.2.请描述冒泡排序算法的基本思想。
3.一个数组中只有0,1两种数字,进行排序,0全部在前,1全部在后OOP部分1.(单选)关于下列代码说法正确的是:A.该类编译失败B.输出:1C.输出:3D.输出:02.试图编译和运行以下代码,将获得什么结果(JAVA)A RType.amethod -1 RType.amethod -1B RType.amethod 99 RType.amethod -1C 99 RType.amethod 99D 编译时错误(Compile time error)3、下边程序运行的结果是? ( )A.BaseB.BaseBaseC.程序编译失败.D.程序运行但没有任何输出4.指出下列程序运行的结果A.good and abcB.good and gbcC.test ok and abcD.test ok and gbcOOP部分-简答题1.抽象类和接口的区别2.静态变量和实例变量的区别?3.String s = new String("xyz");创建了几个String Object ?4.字符串连接时为什么推荐使用StringBuffer而不是直接用String+String 的方式,请简述原因?5.final, finally, finalize的区别。
6.线程继承Thread类如果某个类继承了Thread类,那么此时这个类就是一个线程类,如果要创建此类的线程对象 A extends Thread A a = new A(); a.start()实现Runnable接口如果某个类实现了Runnable接口,此时这个类不是线程类,这个类中只有将线程要执行的任务写好了生命周期:5种状态新建,就绪,运行,阻塞,死亡多线程并发问题:脏数据:污染了数据 -前提条件:多个线程访问同一个对象如何避免脏数据的产生:线程同步 - synchronized可以用来修饰方法,代码块:本质是给对象加锁如果修饰方法:给调用方法的对象(this)加锁如果修饰代码块: sychronized(要加锁的对象){} 一般情况下,加锁的对象都为this线程间的通信 - 线程间要交流生产者消费者Object类下的几个方法来实现了线程间的通信wait() :一定出现在sychronized的方法中notify() notifyAll()线程池:Excutors.newFixedThreadPool(int nThread) - ExcutorServiceexecute()ThreadLocal:将数据绑定到当前线程上,那么在整个线程过程中都可以使用该数据IO流: RandomAccessFile:随机访问流(任意访问流)特殊之处:1.这个流既可以读文件,也可以写文件2.可以定位到文件的任意位置,而且可以获取当前的偏移量RandomAccessFile(File dest,String mode)read() write() - 按照字节seek(long pos)getFilePointer() - long数据库部分-选择题1.当在执行过程中,如果QUANTITY的值是空的话,哪个语句将显示一个0?A.SELECT id_number,100/quantity FROM inventory;B.SELECT id_number,NVL(100/quantity,0) FROM inventory;C.SELECT id_number,NULL(100/quantity,0) FROM inventory;D.SELECT id number,TO CHAR(100/quantity,0) FROM inventory;2.分析下面SQL语句,在什么情况下引起这个语句失败?STUDEN表结构:ID NUMBER(9) FIRST NAME VARCHAR2(25) LAST NAME VARCHAR2(25)A.在数据表中没有学生的名字是Kate HenryB.数据表中学生的名字叫Kate的多于一个C.数据表中的学生的名字叫Kate Henry的多于一个D.FIRST NAME和LAST NAME的值在数据库中是小写的3.分析下面的SQL语句,这个语句为什么会出现一个错误?A.一个子句丢失B.一个关键字丢失C.where子句不能应用在创建表上D.数据类型在新表中不需要被定义4.在SQL语言中,关于主键描述正确的是()(多选)A 只能包含一列B 可以包含两列C 可以包含一列或者多列D 以上都不正确数据库简答题1.写SQL语句显示员工表中工资超过平均工资的员工。
2.假如订单表orders用来存储订单信息,cid代表客户编号,money代表单次订购额,现要查询每个客户的订购次数和每个客户的订购总金额?统计单笔消费超过50元的用户总共的消费次数以及消费总金额,总金额>20003. 表PERSONNEL 的结构如下:在这里, 部门的管理者也看作是雇员,写出SQL语句查询每个雇员的姓名以及管理者的姓名4.ORACLE数据库有哪几种约束类型?5.请分别写出mysql与oracle的分页查询语句(查询第3-第7条数据)6.写一个查询,来查询出挣到佣金(comm)的雇员姓名ename,部门名称,和部门所处的位置loc。
(有employ表和dept表)7.写一个查询,查出在名字里面有一个"A"的所有雇员姓名ename和其所在的部门loc的名称。
8.显示所有薪金高于各自部门平均薪金的人?9.查询平均成绩大于60分的同学的学号和平均成绩;Servlet部分1.JSP九大内置对象,Servlet域对象以及各自的作用范围2.说出Servlet的生命周期?5.请简述mvc架构。
同时说明在自己熟悉的架构中mvc分别对应什么?框架部分1.请描述一下spring MVC工作原理。
2.Spring的核心是什么?JAVA基本部分-选择题1.D2.B解析:此题考查java的浮点运算的精度问题,浮点数是以二进制得形式存储得,如0.5 = 2得-1次方选项A 返回结果0.3999999999999999选项B 返回结果3.75选项C 返回结果0.0 因为30和300都是整数,只要把任何一个定义成浮点型数据,数据会更精确选项D 返回结果0.5 原理同选项C3.AC解析:固定算法,只是用while循环或for循环4.D解析: switch分支结构如果在case的语句体中添加break;语句,那么只要找到对应的case 的常量,就执行对应case常量后的语句,如果没有break语句就继续执行后面所有case 后的语句如果最后有default也会执行。
5.B解析: Java中的位运算符: \int类型占4个字节,一个字节占8位,所以一个int数字占用32位。
>>表示右移,如果该数为正,则高位补0,若为负数,则高位补1; >>>表示无符号右移,也叫逻辑右移,即若该数为正,则高位补0,而若该数为负数,则右移后高位同样补0。
6.BD解析:根据题意,方法名称不变,参数的个数可变,解决方案是用可变参数类型...类型名称比如:int... args 可变参数其本质是一个数组,且必须放在方法参数的最后一个位置,可以接受零个或多个参数,在方法中使用数组方式来访问,比如:args[0] args[1].....简答:1.2.答案:1.冒泡排序的基本思想冒泡排序是交换排序中一种简单的排序方法。
它的基本思想是对所有相邻记录的关键字值进行比效,如果是逆顺(a[j]>a[j+1]),则将其交换,最终达到有序化。
其处理过程为:(1)将整个待排序的记录序列划分成有序区和无序区,初始状态有序区为空,无序区包括所有待排序的记录。
(2)对无序区从前向后依次将相邻记录的关键字进行比较,若逆序将其交换,从而使得关键字值小的记录向上"飘浮"(左移),关键字值大的记录好像石块,向下“堕落”(右移)。
每经过一趟冒泡排序,都使无序区中关键字值最大的记录进入有序区,对于由n个记录组成的记录序列,最多经过n-1趟冒泡排序,就可以将这n个记录重新按关键字顺序排列。