Java几道面试题的笔记

1.Java中求数组char ch[]的长度(元素的个数): ch.length;求字符串s的长度:s.length();

2.arraycopy函数用于拷贝数组,定义如下:

  static void arraycopy(Object src, int srcPos, Object dest, int destPos, int length)

  从指定源数组中复制一个数组,复制从指定的位置开始,到目标数组的指定位置结束。

  src:要被复制的源数组

  srcPos:要被复制的数组的起始位置,从0开始算

  dest:复制到的目标数组

  destPos:要放入的目标数组的位置,从0开始算

  length:被复制的源数组的长度

  NB:注意目标位置的元素将会被替换掉

  例如:

int a=new int[]{1,2,3,4,5};  
int b=new int[]{6,7,8,9}
System.arraycopy(a,2,b,1,3);

  这句之后,b={6,3,4,5}

3.    

byte b1=10+1;//通过
byte b2=2;  byte b3=3;
byte b4=b2+b3;//出错,类型不兼容
byte b5=(byte)(b2+b3);//通过

       问:b1的右边是加法,b4的右边也是加法,为什么第一句通过,第二句报错?

       答:编译器在编译时,会将能够直接计算出来的数据先计算,便于提升效率。因此b1的右边,会被编译器看作11而不是10+1,编译器知道int类型的11转换成byte类型时,没有超过byte类型的表示范围,因此不报错;对于b4,由于b2和b3不是直接量,编译器在编译时不能直接识别b2+b3的值是多少,而在运行时才能够确定,因此编译器不能确定int类型值(b2+b3)在转换成byte类型时是否会超过byte类型的有效表示范围,又因为Java是一种安全的语言,因此编译器会报错,说不能转换成byte类型。而把右边强制转换成byte类型后,编译器的错误就消失了,就像b5一样。因为编译器知道是程序员让编译器这样做的,就算超过byte的表示范围,编译器也会忽略这个问题,因为编译器知道这个问题程序员已经考虑到了。

4. 

while(…){
    if(…){
       break;//这个break不是退出if,而是退出while循环
    }
}

5.分析以下代码出错的原因:

Father.java:

public class Father {
    private String name;
    public Father(String name){
        this.name=name;
    }
}

Son.java

 public class Son extends Father{ }//报错

  答:子类虽然什么都没写,但是系统会为子类添加一个默认的构造函数,如果这个构造函数没有this关键字,则第一句会调用父类的无参构造函数。而父类中没有无参构造函数,因此报错。英文的意思是:隐含的super()默认构造函数没有定义,必须定义一个隐含的构造函数。

  记住:任何一个子类的构造函数,一定会调用父类的构造函数。

6.  

char[] c=new char[]{‘A’,’B’,’C’,’D’,’E’};
System.out.println(c);//输出c内的元素:ABCED
System.out.println(“char[] c:”+c);//输出char[] c:[C+地址(hashCode)

  打印一个boolean的数组时,若参数直接为该数组,则打印结果为 [Z@+地址

  任何值与字符串想加得到的都是字符串

7. Java中的字符串(String)对象永不改变,只能复制

String s1="abc";
String s2=s1;
s1+="def";
System.out.println(s1);//abcdef>>>s1新开辟了一块空间存放结果
System.out.println(s2);//abc

8. 

String str1=”abc”;
String str2=”abc”;                            str1==str2-->true
String str3=”a”+”bc”;                         str1==tr3-->true
String str4=str1+””;                          str1==str4-->false
Integer i1=12;  Integer i2 =12;               i1==i2-->true
Integer i3=128;  Integer i4=128;              i3==i4-->false

  说明:str1的值“abc”放在堆中的常量池中,定义str2时,系统发现字面量”abc”已经在常量池中存在,因此直接将此返回给str2,于是str2和str2共享同一个字面量。创建str3时,编译器会把能够直接计算的值先算出来,因此在编译的时候就发现str3的值是“abc”,于是再将“abc”返回给str3。此时str1,str2,str3共享同一个变量,指向同一个地址。对于str4,编译的时候不能直接计算出它的值,因此需要重新去建一个对象,此时与str1,str2,str3的地址不等

  对于i3,是Integer对象,但是当其值<=127时,Integer类型的相同值的对象就只有一个。但当其值>=128时,Integer i3=128就相当于Integer i3=new Integer();就是说产生了一个新的对象,这个新的Integer对象肯定会跟i4不同地址。

9. 线程安全与不安全比较:

  StringBuffer是Java早期提供的(JDK1.0),速度稍慢,线程安全

  StringBuilder是Java5以后提供的,速度快,线程不安全

  ArrayList和LinkedList,线程不安全  -----   Vector,线程安全

  HashMap,不安全   ---   HashTable,安全

通过以下代码可以将非线程安全的list包装为线程安全的

List list=new ArrayLsit();
list=Collections.synchronizedList(list);

通过以下代码可以将非线程安全的map包装为线程安全的

Map map=new HashMap();
map=Collections.synchronizedMap(map);

10.下面代码的输出结果是:

String regex="\\\\";//4个“\”
String str2="\\\\\\\\";//8个“\”
String str3=str2.replaceAll(regex, "*");
System.out.println(str3);

  答案:****

  解释:字符串中存在转义字符,因此\\\\表示两个斜线,即“\\”,而用在正则表达式中,两个斜线又有一个是转义字符,在正则表达式中就被看成了一个字符“\”。str2其实是4个斜线,因此,用一个斜线作为替换规则,去替换4个斜线,得到4个心号。

11. 

public class EJB {
    class a{
       private static int b=12;
       public void print(){
           System.out.println(b);
       }
    }
}

  b的声明处报错,The field b cannot be declared static; static fields can only be declared in static or top level types。

  静态域只能声明在静态或顶层类型中。

12.

BufferedOutputStream bos=new BufferedOutputStream(new FileOutputStream(“file.dat”));
bos.write(100);

  假设file.dat不存在,运行该程序段后,文件file.dat的字节数为

  A.0         B.1         C.2         D.3

  【选A】。如果不刷新缓冲区,那么写入的字节信息就是写在缓冲区的(也就是内存)。如果显示的调用bos.flush(),或者显示调用bos.close()【bos.close的时候,会自动调用flush方法,清空缓冲区的内容】那么会将缓冲区中的数据写入文件,此时文件就有内容了。

13.  接口java.lang.Comparable<T>

  此接口强行对实现它的每个类的对象进行整体排序。这种排序被称为类的自然排序,类的 compareTo 方法被称为它的自然比较方法。

实现此接口的对象列表(和数组)可以通过 Collections.sort(和 Arrays.sort)进行自动排序。实现此接口的对象可以用作有序映射中的键或有序集合中的元素,无需指定比较器。

  接口java.util.Comparator<T>

  强行对某个对象 collection 进行整体排序的比较函数。可以将 Comparator 传递给 sort 方法(如 Collections.sort 或 Arrays.sort),从而允许在排序顺序上实现精确控制。还可以使用 Comparator 来控制某些数据结构(如有序 set或有序映射)的顺序,或者为那些没有自然顺序的对象 collection 提供排序。

14. InputStream、OutputStream、Reader、Writer都是抽象类。java.util.List extends Collection是接口

15.XML的默认字符集是UTF-8。

16.JavaScript中:

typof(undefined)=undefined; 
typeof(null)=object;

17.解析DOM树时,是从上到下的解析,如果遇到脚本(不是函数,是script之中,function之外的脚本),也依次执行。

18.JS变量没有块级作用域,如果在function中的一个语句块(例如for循环中)定义了一个变量,那么在这个function中,哪怕是出了for的地方,也可以使用这个变量。

19.用select查询rownum的时候,只能使用小于,如果条件是大于,则不会有结果的。

20.下面语句输出什么?

public class T15 {
    public static void main(String[] args) {
        int s=99;
        switch (s) {
        case 0:
            System.out.println();
        default:
            System.out.println("error");
        case 9:
            System.out.println("good");
        case 2:
            System.out.println("best");
        }
    }
}

  答案:error, good, best。

  原因:遇到switch,就依次将可选的值进行比较。这个比较会比较所有的值,不管default在中间还是在最后。如果把除了default的值都比较后,能够找到匹配的,则执行匹配的值的代码。如果之后没有退出(没有break语句),还会依次执行之后的代码。如果没找到匹配的值,那么开始执行default语句。如果之后也没有退出,则还会依次执行default之后的case语句,直到遇到break或者花括号。

21. 如果一个类实现了两个不同的接口,而这两个接口定义了相同的方法时,以下原则不正确的是:(   C   )

  A、如果每个接口的两个方法具有相同的方法声明,则在类中实现一个方法,并且该方法同时满足两个接口;

  B、如果两个方法参数不同,则需要实现两个方法,分别满足各自的接口定义;

  C、如果两个方法参数相同,但返回类型不同,也需要定义两个不同方法,分别返回不同的类型;

  D、如果两个方法参数相同,但返回类型不同,则不能创建满足两个接口的方法。

  解答:C中,不能在一个类里面定义只有返回值相同的两个方法

22.下列有关类继承的说法正确的是:(    C    )

  A、基类中定义了private方法A,派生类中不能定义同名的方法;(可以定义)

  B、基类中定义了protected方法A,派生类中可以重载方法A,并可以将访问级别修改为private;(子类不能减小父类方法的可见性,就是说不能从protected变为private)

  C、基类中定义了private的变量a,派生类中可以定义同样的变量a,并可以将访问级别修改为public;

  D、基类中定义了protected静态变量A,派生类中不能定义同样的变量。(可以定义)

23.两种方式添加一个下拉列表项:

       1).

document.getElementById(‘s1’).options[i]=
new Option(‘shanghai’,’sh’);

       2).

var op=document.createElement(‘option’);
op.value=’sh’;
op.innerHTML=’shanghai’;
document.getElementById(‘s1’).appendChild(op);

24.一个接口可以继承于多个接口

25. 一个抽象类可以继承于一个普通类


转载于:https://my.oschina.net/itblog/blog/204136

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值