最近做项目时,发现在activity的onCreate()和onResume()方法里调用View.getLocationInWindow()时,View.getLocationInWindow()返回空值,觉得很奇怪,因为以前用过,没有发现这个问题,于是调查了一下源码,这里把调查结果做个记录。

首先,看看View.getLocationInWindow()的实现,

1. public void getLocationInWindow(int[] location) {  
2. // When the view is not attached to a window, this method does not make sense  
3. if (mAttachInfo == null) return;  
4.     ... ...  
5. }


这里有注释,说明当view没有绑定到window时,返回在window里的坐标是没有意义的。的确,窗口都没有,哪来的窗口坐标呀!!

其次,看看view何时合适绑定到窗口。通过阅读源码,发现下面这段代码:

1. void dispatchAttachedToWindow(AttachInfo info, int visibility) {  
2. //System.out.println("Attached! " + this);  
3.      mAttachInfo = info;  
4.      ... ...  
5. }


怎么获取到View的位置View.getLocationInWindow()的为0_父窗口


从上图我们可以看出activity.onAttachedToWindow()的调用在View.dispatchAttachedToWindow()之前,此时View还是没有绑定到window上,所以在activity.onAttachedToWindow()里调用View.getLocationInWindow()无效。

最后,何时调用View.dispatchAttachedToWindow()才能得到有效值呢?其实上面已经有答案了,那就是从此以后都可以了,例如activity.onWindowFocusChanged()函数。

备注:

// 获取在当前窗口内的绝对坐标
View.getLocationInWindow()

// 获取在整个屏幕内的绝对坐标,注意这个值是要从屏幕顶端算起,也就是包括了通知栏的高度。
View.getLocationOnScreen()

// 下面一组是获取相对在它父窗口里的坐标。
View.getLeft() , View.getTop(), View.getBottom(), View.getRight()

View.getLocationInWindow()和 View.getLocationOnScreen()在window占据全部screen时,返回值相同,不同的典型情况是在Dialog中时。当Dialog出现在屏幕中间时,View.getLocationOnScreen()取得的值要比View.getLocationInWindow()取得的值要大。



redis的哈希冲突

hash对于我们coder来说并不陌生,在我们使用hashmap和hashtable也许会有其底层实现的疑问,此处以hashmap第底层实现为例子进行说明,同时提出hash冲突的解决办法。 上图就是一个散列表(Hash table,也叫哈希表),是根据关键码值(Key value)而直接进行访问的数据结构。也就是说,它通过把关键码值映射到表中一个位置来访问记