1.Annotation引用非空enum数组返回空数组
  
  首次发现时的环境:JDK 1.8
  
  首次发现所在项目:APIJSON
  
  测试用例:
  
  public enum RequestRole {
  
  /**未登录,不明身份的用户
  
   */
  
  UNKNOWN,
  
  /**已登录的用户
  
   */
  
  LOGIN,
  
  /**联系人,必须已登录
  
   */
  
  CONTACT,
  
  /**圈子成员(CONTACT + OWNER),必须已登录
  
   */
  
  CIRCLE,
  
  /**拥有者,必须已登录
  
   */
  
  OWNER,
  
  /**管理员,必须已登录
  
   */
  
  ADMIN;
  
  //似乎不管怎么做,外部引用后都是空值。并且如果在注解内的位置不是最前的,还会导致被注解的类在其它类中import报错。
  
  //虽然直接打印显示正常,但被@MethodAccess内RequestRole[] GET()等方法引用后获取的是空值
  
  public static final RequestRole[] ALL = {RequestRole.UNKNOWN};//values();//所有
  
  public static final RequestRole[] HIGHS;//高级
  
  static {
  
  HIGHS = new RequestRole[] {OWNER, ADMIN};
  
  }
  
  public static final String[] NAMES = {
  
  UNKNOWN.name(www.mhylpt.com), LOGIN.name(www.thd540.com/), CONTACT.name(www.feifanyule.cn/), CIRCLE.name(), OWNER.name(), ADMIN.name()
  
  };
  
  }
  
  @MethodAccess(
  
  GETS = RequestRole.ALL,
  
  HEADS = RequestRole.HIGHS
  
  )
  
  public class Verify {
  
  }
  
  public class DemoVerifier {
  
  // <TableName, <METHOD, allowRoles>>
  
  // <User, <GET, [OWNER, ADMIN]>>
  
  public static final Map<String, Map<RequestMethod, RequestRole[]>> ACCESS_MAP;
  
  static { //注册权限
  
  ACCESS_MAP =www.michenggw.com new HashMap<String, Map<RequestMethod, RequestRole[]>>();
  
  ACCESS_MAP.put(Verify.class.getSimpleName(www.yigouyule2.cn), getAccessMap(Verify.class.getAnnotation(MethodAccess.class)));
  
  }
  
  public static HashMap<RequestMethod, RequestRole[]> getAccessMap(MethodAccess access) {
  
  if (access == null) {
  
  return null;
  
  }
  
  HashMap<RequestMethod, RequestRole[]> map = new HashMap<>();
  
  map.put(GET, access.GET());
  
  map.put(HEAD, access.HEAD());
  
  map.put(GETS, access.GETS());
  
  map.put(HEADS, access.HEADS());
  
  map.put(POST, access.POST());
  
  map.put(PUT, access.PUT());
  
  map.put(DELETE, access.DELETE());
  
  return map;
  
  }
  
  }
  
  解决方案:
  
  不抽象数组常量ALL,HIGHTS等,而是在每个用到的地方硬编码写死具体的值。
  
  2.ArrayList可通过构造函数传入非指定泛型的List并在get时出错
  
  首次发现时的环境:JDK 1.7
  
  首次发现所在项目:APIJSON
  
  测试用例:
  
  JSONArray arr = new JSONArray(); //com.alibaba.fastjson.JSONArray
  
  arr.add("s");
  
  List<Long> list = new ArrayList<>(arr);
  
  list.get(0); //throw new IllegalArgumentException
  
  解决方案:
  
  1.改用 Open JDK8
  
  2.升级 JDK
  
  注:后面多次测试,已无法复现。
  
  3.基本类型在三元表达式内可赋值为null,编译通过但运行出错
  
  首次发现时的环境: JDK 1.7
  
  测试用例:
  
  int i = true ? null : 0; //Exception in thread "main" java.lang.NullPointerException
  
  首次发现所在项目:ZBLibrary
  
  解决方案:
  
  在给基础类型用3元表达式赋值时,null 先转为基础类型的默认值。
  
  最后再提2个不是bug,但容易引发编程bug的问题:
  
  1.局部变量和同名的全局变量能在一个方法内,编译通过,运行也正常。
  
  public class Test {
  
  int val;
  
  @Override
  
  public String toString() {
  
  val = 1;
  
  String val = "";
  
  return super.toString();
  
  }
  
  }
  
  如果两个变量中间隔了比较长的其它代码,很可能会导致开发人员将两者混淆,导致逻辑认知错误,从而写出或改出有问题的代码。
  
  解决方案:
  
  命名局部变量前先搜素,确保没有已声明的同名全局变量。
  
  2. (非 JDK bug)Gson 通过 TypeToken 转换 List<T> 能写入不属于 T 类型的数据,get 出来赋值给 T 类型的变量/常量报错。
  
  String json = "[1, '2', 'a']";
  
  Type type = new TypeToken<Integer>(){}.getType();
  
  Gson gson = new Gson();
  
  List<Integer> list = gson.fromJson(json, type);
  
  Integer i = list == null || list.isEmpty() ? null : list.get(0); //Exception cannot cast String to Integer
  
  解决方案:
  
  1.手动检查列表内数据都符合泛型 T
  
  2.改用 fastjson 等其它能静态检查类型的库。

发现JDK的3个bug的更多相关文章

  1. 应用服务器中对JDK的epoll空转bug的处理

    原文链接:应用服务器中对JDK的epoll空转bug的处理 前面讲到了epoll的一些机制,与select和poll等传统古老的IO多路复用机制的一些区别,这些区别实质可以总结为一句话, 就是epol ...

  2. 给JDK提的一个bug(关于AbstractQueuedSynchronizer.ConditionObject)

    1. 背景 之前读JUC的AQS源码,读到Condition部分,我当时也写了一篇源码阅读文章--(AbstractQueuedSynchronizer源码解读--续篇之Condition)[http ...

  3. jdk 10.0.2 bug修复

    之前记录过jdk9+版本的1个bug,某些情况下会导致方法执行二遍,今天早上打开笔记本(mac),弹出一个框提示jdk升级10.0.2,顺手点了一下,然后验证了下该bug,发现居然fix掉了,推荐大家 ...

  4. JDK的3个bug啊,你get到了吗?

    1.Annotation引用非空enum数组返回空数组 首次发现时的环境:JDK 1.8 首次发现所在项目:APIJSON 测试用例: publicenumRequestRole {/**未登录,不明 ...

  5. JDK中的并发bug?

    最近研究Java并发,无意中在JDK8的System.console()方法的源码中翻到了下面的一段代码: private static volatile Console cons = null; / ...

  6. 最近调试HEVC中码率控制, 发现HM里面一个重大bug

    最近调试HEVC中码率控制, 发现里面一个重大bug! 码率控制中有这么一个函数: Int TEncRCGOP::xEstGOPTargetBits( TEncRCSeq* encRCSeq, Int ...

  7. eclipse导入别的项目后发现jdk版本不一样,该如何解决呢?

    当我们导入其他人的项目的时候,发现导入的项目的jdk版本与我们使用电脑上的版本不同,该如何解决呢? 选中项目右键 --> Properties --> Build Path --> ...

  8. C#.Net ComboBox控件设置DropDownList之后背景颜色问题,以及发现的微软的一个BUG

    先说背景颜色问题怎么处理. C#.Net WinForm中如果设置ComboBox的DropDownStyle为DropDownList,控件背景色会变成灰色,并且这个时候ComboBox控件的Bac ...

  9. 我好像发现了一个Go的Bug?

    从一次重构说起 这事儿还得从一次重构优化说起. 最近在重构一个路由功能,由于路由比较复杂,需求变化也多,于是想通过责任链模式来重构,刚好这段时间也在 Sentinel-Go 中看到相关源码. 用责任链 ...

随机推荐

  1. html5 canvas中CanvasGradient对象用法

    html5 中canvas提供了强大的渲染样式,可以实现一些比较复杂的样式设置,今天学习了CanvasGradient对象可以实现一个颜色的渐变 CanvasGradient对象可以实现两种不同形式的 ...

  2. HDU.3177Crixalis's Equipment(贪心)

    题目来源:3177 题目分析:一只蝎子要搬动一堆装备到一个容量为V的洞里面,每个装备有两个属性,一个是固有体积A,放置之后洞的剩余空间就会减少A,一个是移动体积B,只有当体积B小于等于当前洞的剩余体积 ...

  3. Servlet学习笔记06——什么是转发,路径,状态管理?

    1.include指令 (1)作用: 告诉容器,在将jsp转换成Servlet时,将 某个文件的内容插入到该指令所在的位置. (2)语法: <%@ include file="&quo ...

  4. linux 安装 zookeeper

    第一步 下载 zookeeper: http://archive.apache.org/dist/zookeeper/ 第二步 解压: tar -xzvf zookeeper-3.4.5.tar.gz ...

  5. IDEA 编辑框光标闪烁

    依次打开如下菜单: File -> Settings -> Editor -> General -> Appearance -> 选中 Caret blinking (m ...

  6. linux面试集

    shell:1.$# 和 $*之类的特殊变量 特殊变量列表 变量 含义 $0 当前脚本的文件名 $n 传递给脚本或函数的参数.n是一个数字,表示第几个参数.例如,第一个参数就是$1 $# 传递给脚本或 ...

  7. python join() 提示UnicodeDecodeError: 'utf8' codec can't decode byte 0xcb in position 0: unexpected end of的原因及解决办法

    问题: 在使用join()将列表元素连接成字符串时出错如下 return split.join(result) UnicodeDecodeError: 'utf8' codec can't decod ...

  8. Python生成器、装饰器

    ## 生成器 - 生成器是用来创建Python序列的一个对象 - 通常生成器是为迭代器产生数据的 - 例如range()函数就是一个生成器 - 每次迭代生成器时,它都会记录上一次调用的位置,并返回下一 ...

  9. CI 框架源码解析一之入口文件 index.php

    Index.php作为CI框架的入口文件,源码分析,自然而然由此开始.在源码分析的过程中,我们并不会逐行进行解释,而只解释核心的功能和实现,如果英文水平很好的话,读过index.php文件的英文注释之 ...

  10. POJ 2079 最大三角形面积(凸包)

    Triangle Description Given n distinct points on a plane, your task is to find the triangle that have ...