Java面试基础题

第一,谈谈final, finally, finalize的区别。

		final:修饰符(关键字)如果一个类被声明为final,意味着它不能再派生出新的子类,不能作为父类被继承。因此一个类不能既被声明为 abstract的,又被声				明为 final的。将变量或方法声明为final,可以保证它们在使用中不被改变。被声明为final的变量必须在声明时给定初值,而在以后的引用中只能读				取,不可修改。被声明为final的方法也同样只能使用,不能重载
		
		finally:再异常处理时提供 finally 块来执行任何清除操作。如果抛出一个异常,那么相匹配的 catch 子句就会执行,然后控制就会进入 finally 块
			(如果有的话)。
  		
		finalize:方法名。Java 技术允许使用 finalize()方法在垃圾收集器将对象从内存中清除出去之前做必要的清理工作。这个方法是由垃圾收集器在确定这个				对象没有被引用时对这个对象调用的。它是在 Object 类中定义的,因此所有的类都继承了它。子类覆盖 finalize() 方法以整理系统资源或者执行				其他清理工作。 finalize():方法是在垃圾收集器删除对象之前对这个对象调用的。



	第二,Anonymous Inner Class (匿名内部类) 是否可以extends(继承)其它类,是否可以implements(实现)interface(接口)?

		匿名的内部类是没有名字的内部类。不能extends(继承) 其它类,但一个内部类可以作为一个接口,由另一个内部类实现。

	第四,&和&&的区别。

		&是位运算符。&&是布尔逻辑运算符。

	第五,HashMap和Hashtable的区别。

		都属于Map接口的类,实现了将惟一键映射到特定的值上。
  		HashMap 类没有分类或者排序。它允许一个 null 键和多个 null 值。
  		Hashtable 类似于 HashMap,但是不允许 null 键和 null 值。它也比 HashMap 慢,因为它是同步的。

	第六,Collection 和 Collections的区别。
  		Collections是个java.util下的类,它包含有各种有关集合操作的静态方法。
  		Collection是个java.util下的接口,它是各种集合结构的父接口。

	第八,GC是什么? 为什么要有GC? (基础)。
  		GC是垃圾收集器。Java 程序员不用担心内存管理,因为垃圾收集器会自动进行管理。要请求垃圾收集,可以调用下面的方法之一:
  		System.gc()
  		Runtime.getRuntime().gc()

	 第九,String s = new String("xyz");创建了几个String Object?
  		两个对象,一个是“xyx”,一个是指向“xyx”的引用对象s。

	第十,Math.round(11.5)等於多少? Math.round(-11.5)等於多少?
  		Math.round(11.5)返回(long)12,Math.round(-11.5)返回(long)-11;

	第十一,short s1 = 1; s1 = s1 + 1;有什么错? short s1 = 1; s1 += 1;有什么错?
  		short s1 = 1; s1 = s1 + 1;有错,s1是short型,s1+1是int型,不能显式转化为short型。可修改为s1 =(short)(s1 + 1) 。short s1 = 1; s1 += 1正确。

	第十二,sleep() 和 wait() 有什么区别? 搞线程的最爱
 		 sleep()方法是使线程停止一段时间的方法。在sleep 时间间隔期满后,线程不一定立即恢复执行。这是因为在那个时刻,其它线程可能正在运行而且没有被调		  	  度为放弃执行,除非(a)“醒来”的线程具有更高的优先级,(b)正在运行的线程因为其它原因而阻塞。
 		 wait()是线程交互时,如果线程对一个同步对象x 发出一个wait()调用,该线程会暂停执行,被调对象进入等待状态,直到被唤醒或等待时间到。

	第十四,数组有没有length()这个方法? String有没有length()这个方法?
  		数组没有length()这个方法,有length的属性。
  		String有length()这个方法。

	第十五,Overload和Override的区别。Overloaded的方法是否可以改变返回值的类型?
  		方法的重写Overriding和重载Overloading是Java多态性的不同表现。重写Overriding是父类与子类之间多态性的一种表现,重载Overloading是一个类中多态性			的一种表现。如果在子类中定义某方法与其父类有相同的名称和参数,我们说该方法被重写 (Overriding)。子类的对象使用这个方法时,将调用子类中的定义,			对它而言,父类中的定义如同被“屏蔽”了。如果在一个类中定义了多个同名的方法,它们或有不同的参数个数或有不同的参数类型,则称为方法的重载				(Overloading)。Overloaded的方法是可以改变返回值的类型。 

	第十六,Set里的元素是不能重复的,那么用什么方法来区分重复与否呢? 是用==还是equals()? 它们有何区别?
  		Set里的元素是不能重复的,那么用iterator()方法来区分重复与否。equals()是判读两个Set是否相等。
  		equals()和==方法决定引用值是否指向同一对象equals()在类中被覆盖,为的是当两个分离的对象的内容和类型相配的话,返回真值。

	第十八,error和exception有什么区别?
 		 error 表示恢复不是不可能但很困难的情况下的一种严重问题。比如说内存溢出。不可能指望程序能处理这样的情况。
 		 exception 表示一种设计或实现问题。也就是说,它表示如果程序运行正常,从不会发生的情况。

	第二十,abstract class和interface有什么区别?
  		声明方法的存在而不去实现它的类被叫做抽象类(abstract class),它用于要创建一个体现某些基本行为的类,并为该类声明方法,但不能在该类中实现该类			的情况。不能创建abstract 类的实例。然而可以创建一个变量,其类型是一个抽象类,并让它指向具体子类的一个实例。不能有抽象构造函数或抽象静态方法。			Abstract 类的子类为它们父类中的所有抽象方法提供实现,否则它们也是抽象类为。取而代之,在子类中实现该方法。知道其行为的其它类可以在类中实现这些			方法。
  		接口(interface)是抽象类的变体。在接口中,所有方法都是抽象的。多继承性可通过实现这样的接口而获得。接口中的所有方法都是抽象的,没有一个有程序			体。接口只可以定义static final成员变量。接口的实现与子类相似,除了该实现类不能从接口定义中继承行为。当类实现特殊接口时,它定义(即将程序体给			予)所有这种接口的方法。然后,它可以在实现了该接口的类的任何对象上调用接口的方法。由于有抽象类,它允许使用接口名作为引用变量的类型。通常的动			态联编将生效。引用可以转换到接口类型或从接口类型转换,instanceof 运算符可以用来决定某对象的类是否实现了接口。

	第二十三,启动一个线程是用run()还是start()?
  		启动一个线程是调用start()方法,使线程所代表的虚拟处理机处于可运行状态,这意味着它可以由JVM调度并执行。这并不意味着线程就会立即运行。run()方法			可以产生必须退出的标志来停止一个线程。

	第二十六,当一个线程进入一个对象的一个synchronized方法后,其它线程是否可进入此对象的其它方法?
  		不能,一个对象的一个synchronized方法只能由一个线程访问。

	第三十,当一个对象被当作参数传递到一个方法后,此方法可改变这个对象的属性,并可返回变化后的结果,那么这里到底是值传递还是引用传递?
  		是值传递。Java 编程语言只由值传递参数。当一个对象实例作为一个参数被传递到方法中时,参数的值就是对该对象的引用。对象的内容可以在被调用的方法中			改变,但对象的引用是永远不会改变的。

	第三十一,swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上?
 		 switch(expr1)中,expr1是一个整数表达式。因此传递给 switch 和 case 语句的参数应该是 int、 short、 char 或者 byte。long,string 都不能作用于		 	  swtich。

	第三十二,编程题: 写一个Singleton出来。
  		Singleton模式主要作用是保证在Java应用程序中,一个类Class只有一个实例存在。
  		一般Singleton模式通常有几种种形式:
  		第一种形式: ??定义一个类,它的构造函数为private的,它有一个static的private的该类变量,在类初始化时实例话,通过一个public的getInstance方法获取			对它的引用,继而调用其中的方法。
  		public class Singleton {
  		private Singleton(){}
  		//在自己内部定义自己一个实例,是不是很奇怪?
  		//注意这是private 只供内部调用
  		private static Singleton instance = new Singleton();
  		//这里提供了一个供外部访问本class的静态方法,可以直接访问
  		public static Singleton getInstance() {
  		return instance;
  		}
  		}
  		第二种形式:
  		public class Singleton {
  		private static Singleton instance = null;
  		public static synchronized Singleton getInstance() {
  		//这个方法比上面有所改进,不用每次都进行生成对象,只是第一次使用时生成实例,提高了效率!
  		if (instance==null)
  			instance=new Singleton();
  		return instance;   
		}
  		}

	56、ArrayList和Vector的区别,HashMap和Hashtable的区别 

		答:就ArrayList与Vector主要从二方面来说. 
		一.同步性:Vector是线程安全的,也就是说是同步的,而ArrayList是线程序不安全的,不是同步的  
		二.数据增长:当需要增长时,Vector默认增长为原来一培,而ArrayList却是原来的一半 
 
		就HashMap与HashTable主要从三方面来说。 
		一.历史原因:Hashtable是基于陈旧的Dictionary类的,HashMap是Java 1.2引进的Map接口的一个实现 
		二.同步性:Hashtable是线程安全的,也就是说是同步的,而HashMap是线程序不安全的,不是同步的 
		三.值:只有HashMap可以让你将空值作为一个表的条目的key或value 

	58、多线程有几种实现方法,都是什么?同步有几种实现方法,都是什么? 

		答:多线程有两种实现方法,分别是继承Thread类与实现Runnable接口 
		同步的实现方面有两种,分别是synchronized,wait与notify

	59.编程题:现在输入n个数字,以逗号,分开;然后可选择升或者降序排序;按提交键就在另一页面显示按什么 排序,结果为,  ,提供reset


		答案(1)  public static String[] splitStringByComma(String source){
           if(source==null||source.trim().equals(""))
                   return null;
           StringTokenizer commaToker =  new StringTokenizer(source,",");
           String[] result = new String[commaToker.countTokens()];
           int i=0;
           while(commaToker.hasMoreTokens()){
                   result[i] = commaToker.nextToken();
                   i++;
           }
           return result;
  	}

	循环遍历String数组
	Integer.parseInt(String s)变成int类型

	组成int数组
	Arrays.sort(int[] a),

	a数组升序 降序可以从尾部开始输出



	7、编程:编写一个截取字符串的函数,输入为一个字符串和字节数,输出为按字节截取的字符串。 但是要保证汉字不被截半个,如“我ABC”4,应该截为“我AB”,输入“我ABC汉DEF”,6,应该输出为“我ABC”而不是“我ABC+汉的半个”。 

 

答:代码如下: 

 

package test; 

 

 


class SplitString 

 

{ 

 

String SplitStr; 

 

int SplitByte; 

 

public SplitString(String str,int bytes) 

 

{ 

 

SplitStr=str; 

 

SplitByte=bytes; 

 

System.out.println("The String is:′"+SplitStr+"′;SplitBytes="+SplitByte); 

 

} 

 

public void SplitIt() 

 

{ 

 

int loopCount; 

 

loopCount=(SplitStr.length()%SplitByte==0)?(SplitStr.length()/SplitByte):(SplitStr.length()/Split 

 

Byte+1); 

 

System.out.println("Will Split into "+loopCount); 

 

for (int i=1;i<=loopCount ;i++ ) 

 

{ 

 

if (i==loopCount){ 

 

System.out.println(SplitStr.substring((i-1)*SplitByte,SplitStr.length())); 

 

} else { 

 

System.out.println(SplitStr.substring((i-1)*SplitByte,(i*SplitByte))); 

 

} 

 

} 

 

} 

 

public static void main(String[] args) 

 

{ 

 

SplitString ss = new SplitString("test中dd文dsaf中男大3443n中国43中国人 

 

 


0ewldfls=103",4); 

 

ss.SplitIt(); 

 

} 

 

} 

 







		

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值