关于面试的一些小记

原创 2015年07月08日 09:44:18

感谢生命中的这些贵人~在很牛的时候不抛弃我们~在关键的时候点醒我们~


1  下面输出结果是?

public static void main(String[] args) {
		Integer a = 123;
		Integer b = new Integer(123);
		System.out.println("result a==b is: " + (a == b));
		Integer a2 = 100;
		Integer b2 = 100;
		System.out.println("result a2==b2 is: " + (a2 == b2));
		Integer a3 = 128;
		Integer b3 = 128;
		System.out.println("result a3==b3 is: " + (a3 == b3));

	}

答案:false  true false 

简解:

JVM中一个字节以下的整型数据会在JVM启动的时候加载进内存,除非用new Integer()显式的创建对象,否则都是同一个对象;Integer中valueOf源码

 public static Integer valueOf(int i) {
        assert IntegerCache.high >= 127;
        if (i >= IntegerCache.low && i <= IntegerCache.high)
            return IntegerCache.cache[i + (-IntegerCache.low)];
        return new Integer(i);
    }
可以看出只要超过-127~128这个范围,就会new Integer创建新的对象,==比较就会返回false

2  HashMap怎么判断是否存在某个key?为什么使用?有没有别的办法?containsKey方法原理?能用get方法判断吗?

简解:

使用containsKey方法判断;containsKey方法源码简单介绍

    /**
     * Returns <tt>true</tt> if this map contains a mapping for the
     * specified key.
     *
     * @param   key   The key whose presence in this map is to be tested
     * @return <tt>true</tt> if this map contains a mapping for the specified
     * key.
     */
    public boolean containsKey(Object key) {
        return getEntry(key) != null;
    }
 /**
     * Returns the entry associated with the specified key in the
     * HashMap.  Returns null if the HashMap contains no mapping
     * for the key.
     */
    final Entry<K,V> getEntry(Object key) {
        if (size == 0) {
            return null;
        }

        int hash = (key == null) ? 0 : hash(key);
        for (Entry<K,V> e = table[indexFor(hash, table.length)];
             e != null;
             e = e.next) {
            Object k;
            if (e.hash == hash &&
                ((k = e.key) == key || (key != null && key.equals(k))))
                return e;
        }
        return null;
    }
注意上面的判断 e.hash == hash &&  ((k = e.key) == key || (key != null && key.equals(k))) 需要hash值相同,equals相等才认为是同一个key;

不能用get方法,原因是hashmap是可以保存<null,null>、<null,value>或者<key,null>key和value都可以为null,如果value为null的时候是没有办法判断key不存在还是存在值为null

3运行时结果

public static void main(String[] args) {
		Integer a = null;
		
		Integer b = (Integer) a; //1
		Integer c = (int)a;      //2
		
		System.out.println("result a == 3 is: " + (a == 3)); //3 
		System.out.println("result a == new Integer(3) is: " + (a == new Integer(3))); //4
	}
答案:1 正常 2运行时报空指针异常 3 运行时报空指针异常 4 false
简解:对于第二行写法,本人没有这么写过,待补充~


4 下面运行结果

public static void main(String[] args) {
		String a = "123";
		String b = "123";
		System.out.println("1.result for a == b is: "+(a == b));
		String a2 = "123"; 
		String b2 = "1"+"23";
		System.out.println("2.result for a2 == b2 is: "+(a2 == b2));
		String a3 = "123"; 
		String b3 = new String("123");
		System.out.println("3.result for a3 == b3 is: "+(a3 == b3));
		String a4 = "123"; 
		String b4 = "1" + new String("23");
		System.out.println("4.result for a4 == b4 is: "+(a4 == b4));
		String a5 = new String("123");
		String b5 = new String("123");
		System.out.println("5.result for a5 == b5 is: "+(a5 == b5));
	}
答案:

1.result for a == b is: true
2.result for a2 == b2 is: true
3.result for a3 == b3 is: false
4.result for a4 == b4 is: false
5.result for a5 == b5 is: false

分析:参见这篇文章吧  http://blog.csdn.net/xbkaishui/article/details/6284702 有启发的第四题 +连接的对象的地址是无法确定 的, 第二个中“1”和“23”在编译期能确定,和“123”是等效的









版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

mysql小记: 面试可用,公司开发可用

本文将会持续更新,有兴趣的小伙伴可以持续关注,有错误的地方希望大家慷慨指点。 学习参照: msyql官方文档:http://dev.mysql.com/doc/ 日期:2016-6-30 ...

JAVA面试算法小记

面试笔记 算法

ThoughtWorks面试小记

首先是电话面,很轻松,主要是讲讲过去的项目经历,用了什么技术呀,感觉比较看重你空闲时候的经历,在下班之后做了些什么,看了什么书,都可以加分。最后会有一次简短的英语交流··这个被囧到了,都没准备,感觉表...
  • nxvan
  • nxvan
  • 2013-03-11 13:39
  • 601

腾讯实习生面试经验小记

昨天签约拿到了腾讯实习生offer,这是我回复同样参加腾讯实习生招聘的高中校友的Email中的内容,共享一下: 一面是“技术面” 二面是“压力面” HR面基本是聊聊天,看人这个人性格、意...

2017前端第一次面试小记

转载自:https://juejin.im/post/58c75619da2f605dc5b0f4ff 不是博主本人面试哦~网上朋友的一次面试经历,给大家分享一下。 太久没有面试过了,第一...

2016暑期实习面试小记

楔子隔了好长时间没写博客了,这一段时间基本忙于实习以及实验室的事情。从2月底到3月18日收到阿里的offer短短十几天,经历了不少面试,这里把主要的经历简单的记录总结一下,也为接下来的学习和工作做一个...

某家公司面试小记

面试比较水,没问什么。 一个是,圆角怎么实现,把知道的都说一下,不用管兼容性。我说了,一个css3,这个c

面试小记——listview的问题

文章概述: 1.前提 2.什么是item复用 3.为什么会错乱 4.解决错乱

阿里面试小记

稀里糊涂通过阿里的在线笔试后,就开始准备去北京的面试了。       然后开始恶补我的数据结构,各种排序、树、图,为了面试也是拼了。我面试的是java研发的职位,冥冥之中我就感觉到肯定没戏,因为目前我...

面试小记

——写在前面的话     其实我是一个比较凌乱的人,没考虑过将来会怎么样,或者说我不想去考虑。年后换了新部门之后,之前的所有都被打破了,我也不知道怎么才好。想着要不就换一个环境吧。然后考完科目二之后...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)