java下载大量零碎文件_java零碎知识

1.如何比较两个对象,比如学生类,根据属性年龄比较大小

解答:让类实现Comparable接口,关于Comparable接口的扩展知识,可参考http://www.cnblogs.com/xujian2014/p/5215082.html

package ComparableTest;

public class Person implements Comparable {

private int id;

private String stuName;

private int stuAge;

public int getId() {

return id;

}

public void setId(int id) {

this.id = id;

}

public String getStuName() {

return stuName;

}

public void setStuName(String stuName) {

this.stuName = stuName;

}

public int getStuAge() {

return stuAge;

}

public void setStuAge(int stuAge) {

this.stuAge = stuAge;

}

@Override

public int compareTo(Person obj) {

if (this.stuAge > obj.stuAge) {

return 1;

} else if (this.stuAge == obj.stuAge) {

return 0;

} else {

return -1;

}

}

public Person(int id, String stuName, int stuAge) {

super();

this.id = id;

this.stuName = stuName;

this.stuAge = stuAge;

}

}

2.给你一个set 如何根据学生类的name进行对象排序

解答:这道题类似于下面这种需求,如何根据对象的属性,对集合(list / set)中的对象进行排序

一:针对list

通过java.util.Collections的sort方法,有2个参数,第一个参数是list对象,第二个参数是new Comparator(){}方法,这个方法实现了compare()方法,具体代码如下所示:

public class ListSort {

public static void main(String[] args) {

List personList = new ArrayList();

personList.add(new Person("王五",32)) ;

personList.add(new Person("张三",30)) ;

personList.add(new Person("赵六",33)) ;

personList.add(new Person("李四",31)) ;

personList.add(new Person("孙七",33)) ;

Collections.sort(personList, new Comparator() {

@Override

public int compare(Person p1, Person p2) {

if(p1.age>p2.age){

return 1;

}

else if(p1.age

return 0;

}

else{

return p1.name.compareTo(p2.name) ; // 调用String中的compareTo()方法

}

}

});

System.out.println(personList);

}

}

class Person {

public String name ;

public int age ;

public Person(String name,int age){

this.name = name ;

this.age = age ;

}

public String toString(){

return "姓名:" + this.name + ";年龄:" + this.age ;

}

}

代码执行的结果为:

[姓名:张三;年龄:30, 姓名:李四;年龄:31, 姓名:王五;年龄:32, 姓名:孙七;年龄:33, 姓名:赵六;年龄:33]

二:针对set

要排序的对象所属的类implements Comparable接口,重写了compareTo()方法,具体代码如下所示:

public class TreeSetDemo4{

public static void main(String args[]){

Set allSet = new TreeSet() ;

allSet.add(new Person("赵六",33)) ;

allSet.add(new Person("张三",30)) ;

allSet.add(new Person("王五",32)) ;

allSet.add(new Person("李四",31)) ;

allSet.add(new Person("孙七",33)) ;

System.out.println(allSet) ;

}

}

class Person implements Comparable{

private String name ;

private int age ;

public Person(String name,int age){

this.name = name ;

this.age = age ;

}

public String toString(){

return "姓名:" + this.name + ";年龄:" + this.age ;

}

public int compareTo(Person per){

if(this.age>per.age){

return 1 ;

}else if(this.age

return -1 ;

}else{

return this.name.compareTo(per.name) ; // 调用String中的compareTo()方法

}

}

}

代码执行的结果为:

[姓名:张三;年龄:30, 姓名:李四;年龄:31, 姓名:王五;年龄:32, 姓名:孙七;年龄:33, 姓名:赵六;年龄:33]

3.给你一台服务器,要你装Tomcat,你得做什么

安装java jdk,配置好相关环境变量;tomcat相关启动、停止脚本给予相关执行权限

4.怎么取map中的key

两种方法 Map 的 map.keySet();和map.entrySet();方法

public class MapTest {

public static void main(String[] args) {

getKeySet();

getEntrySet();

}

//根据Map 中的 keySet()方法获取

public static void getKeySet(){

System.out.println("--------keySet()方法获取-------------");

Map map = new HashMap();

map.put(1, "a");

map.put(2, "b");

System.out.println(map.keySet());

Collection s = map.keySet();

System.out.println(s);

Iterator iter2 = (Iterator)map.keySet().iterator();

while(iter2.hasNext()){

System.out.print(iter2.next() + ", ");

}

System.out.println("========得到value的方法========");

Collection c = map.values();

System.out.println(c);

Iterator iter1 = (Iterator)map.values().iterator();

while(iter1.hasNext()){

System.out.print(iter1.next() + ", ");//一个一个获取value值

}

}

//根据Map 中的 entrySet()方法获取

public static void getEntrySet(){

System.out.println("--------entrySet()方法获取-------------");

Map map = new HashMap();

map.put(1, "a");

map.put(2, "b");

System.out.println(map.entrySet());

Collection s = map.entrySet();

System.out.println(s);

Iterator iter2 = (Iterator)map.entrySet().iterator();

while(iter2.hasNext()){

System.out.print(iter2.next() + ", ");

}

}

}

5.hashmap是怎么存储数据的

hashmap 实质上一个数组和链表的结合体,这个称为“散列表”。对于hashmap存储可以这样理解,数组用于存储key,链表用于存储value,每个链表都链接在数组中的一个元素上。arraylist 实质上就是一个顺序的动态数组,开始时以一默认值开一数组,满了后再扩容,且实现了动态添加和删除。二者性能区别:hashmpa 用于快速查找,但是arraylist基本上不浪费空间,各有利弊吧。

6.什么业务场景下我们使用递归写法,请举一个例子,并予以说明

比如给定一个文件目录,然后要你查找这个目录下面是否存在某个文件,那么需要递归这个目录结构;比如类型级别;比如会员等级,查找某个会员下面所有的下家

7.简述hibernate和mybatis的区别,你偏向使用哪种,为什么?

https://www.jianshu.com/p/08535985b512

8.在使用springmvc进行开发时,是如何对数据进行封装的和校验的,对于restful的传输风格是否了解,说说它的特点

关于使用springmvc进行开发时,是如何对数据进行封装的,可参考

https://www.cnblogs.com/shanheyongmu/p/5869345.html

关于使用springmvc进行开发时,是如何对数据进行校验的,可参考

https://www.cnblogs.com/shanheyongmu/p/5871312.html

对于restful的传输风格是否了解,说说它的特点,可参考

https://www.cnblogs.com/shanheyongmu/p/5882125.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值