JSP 中使用cache取值出錯解決辦法
JSP 中使用cache取值出錯解決辦法
這段時間發(fā)現(xiàn)系統(tǒng)取數(shù)據(jù)過程中,偶爾出現(xiàn)取數(shù)據(jù)錯亂的問題,按邏輯應(yīng)該取出A數(shù)據(jù),結(jié)果取出了B數(shù)據(jù)。仔細(xì)檢查了代碼,
發(fā)現(xiàn)代碼邏輯沒有問題,瞬間就蒙了,是哪里出現(xiàn)問題了呢。仔細(xì)想了一下,以前都沒出現(xiàn)問題,自從加了緩存之后就偶爾出現(xiàn)了問題,那肯定問題是緩存有問題。
仔細(xì)研究了緩存的源碼,原來問題出現(xiàn)在DefaultKeyGenerator生成key上面。代碼如下:
public class DefaultKeyGenerator implements KeyGenerator { public static final int NO_PARAM_KEY = 0; public static final int NULL_PARAM_KEY = 53; public Object generate(Object target, Method method, Object... params) { if (params.length == 1) { return (params[0] == null ? NULL_PARAM_KEY : params[0]); } if (params.length == 0) { return NO_PARAM_KEY; } int hashCode = 17; for (Object object : params) { hashCode = 31 * hashCode + (object == null ? NULL_PARAM_KEY : object.hashCode()); } return Integer.valueOf(hashCode); } }
從源碼中我們發(fā)現(xiàn),當(dāng)參數(shù):params有一個或0的時候,直接返回NULL_PARAM_KEY或者參數(shù)params[0],假如params參數(shù)大于1的時候返回的是各個參數(shù)的hash值相加的值+31*17。這樣就出現(xiàn)問題了,雖然取A數(shù)據(jù)與取B數(shù)據(jù)的各個參數(shù)的值不一樣,但是有可能它們參數(shù)的hashcode值是一樣的,那么就可能出現(xiàn)取A數(shù)據(jù)把B數(shù)據(jù)取出來了。(cache中就像map一樣,有key和value,根據(jù)key來取value值)。
比如下面代碼,雖然參數(shù)值不一樣但是key是相同的。
public static void main(String argv[]) { DefaultKeyGenerator g = new DefaultKeyGenerator(); Integer param0 = 1000000759; String param1 = "11"; System.out.println(" param0="+param0+", param1="+param1+" generate key: "+g.generate(null,null,param0,param1)); Integer param01 = 1000000757; String param11 = "31"; System.out.println("param01="+param01+",param11="+param11+" generate key: "+g.generate(null,null,param01,param11)); }
運行結(jié)果如下:
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
SSM框架JSP使用Layui實現(xiàn)layer彈出層效果
這篇文章主要介紹了SSM框架JSP使用Layui實現(xiàn)layer彈出層效果,文章通過實例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-12-12jsp中sitemesh修改tagRule技術(shù)分享
這篇文章主要介紹了jsp中sitemesh修改tagRule技術(shù)以及詳細(xì)代碼分析,有需要的朋友跟著小編一起學(xué)習(xí)參考下吧。2017-12-12JSP 點擊鏈接后下載文件(相當(dāng)于右鍵另存)功能
JSP 點擊鏈接后下載文件(相當(dāng)于右鍵另存)功能實現(xiàn)代碼。2009-07-07Eclipse XSD 生成枚舉類型的Schema的實例詳解
這篇文章主要介紹了Eclipse XSD 生成枚舉類型的Schema的實例詳解的相關(guān)資料,希望通過本能幫助到大家,需要的朋友可以參考下2017-09-09jsp利用echarts實現(xiàn)報表統(tǒng)計的實例
echarts用來做數(shù)據(jù)報表的一個展示效果了,本文介紹了jsp利用echarts實現(xiàn)報表統(tǒng)計的實例,具有一定的參考價值,感興趣的小伙伴們可以參考一下。2016-10-10