代码精进之路
范学雷
Oracle首席软件工程师,Java SE安全组成员,OpenJDK评审成员
立即订阅
6350 人已学习
课程目录
已完结 47 讲
0/4登录后,你可以任选4讲全文学习。
开篇词 (1讲)
开篇词 | 你写的每一行代码,都是你的名片
免费
第一模块:代码“规范”篇 (16讲)
01 | 从条件运算符说起,反思什么是好代码
02 | 把错误关在笼子里的五道关卡
03 | 优秀程序员的六个关键特质
04 | 代码规范的价值:复盘苹果公司的GoToFail漏洞
05 | 经验总结:如何给你的代码起好名字?
06 | 代码整理的关键逻辑和最佳案例
07 | 写好注释,真的是小菜一碟吗?
08 | 写好声明的“八项纪律”
09 | 怎么用好Java注解?
10 | 异常处理都有哪些陷阱?
11 | 组织好代码段,让人对它“一见钟情”
12丨组织好代码文件,要有“用户思维”
13 | 接口规范,是协作的合约
14 | 怎么写好用户指南?
15 | 编写规范代码的检查清单
16丨代码“规范”篇用户答疑
第二模块:代码“经济”篇 (14讲)
17 | 为什么需要经济的代码?
18丨思考框架:什么样的代码才是高效的代码?
19 | 怎么避免过度设计?
20 | 简单和直观,是永恒的解决方案
21 | 怎么设计一个简单又直观的接口?
22丨高效率,从超越线程同步开始!
23 | 怎么减少内存使用,减轻内存管理负担?
24 | 黑白灰,理解延迟分配的两面性
25 | 使用有序的代码,调动异步的事件
26 | 有哪些招惹麻烦的性能陷阱?
27 | 怎么编写可持续发展的代码?
28 | 怎么尽量“不写”代码?
29 | 编写经济代码的检查清单
30丨“代码经济篇”答疑汇总
第三模块:代码“安全”篇 (14讲)
31 | 为什么安全的代码这么重要?
32 | 如何评估代码的安全缺陷?
33 | 整数的运算有哪些安全威胁?
34 | 数组和集合,可变量的安全陷阱
35 | 怎么处理敏感信息?
36 | 继承有什么安全缺陷?
37 | 边界,信任的分水岭
38 | 对象序列化的危害有多大?
39 | 怎么控制好代码的权力?
40 | 规范,代码长治久安的基础
41 | 预案,代码的主动风险管理
42 | 纵深,代码安全的深度防御
43 | 编写安全代码的最佳实践清单
44 | “代码安全篇”答疑汇总
加餐 (1讲)
Q&A加餐丨关于代码质量,你关心的那些事儿
结束语 (1讲)
结束语|如何成为一个编程好手?
代码精进之路
登录|注册

09 | 怎么用好Java注解?

范学雷 2019-01-23
如果你使用面向对象的概念和技术有一段时间了,不知道你会不会有这样的困惑: 面向对象技术带来的麻烦,一点都不比它带来的好处少!
比如说,我们辛辛苦苦继承了一个类,重写了它的方法。过几天,这个类居然修改了它的接口,而且没人通知我们。然后,我们写的子类还可以美滋滋地编译,运行,就是总出错误,怎么调试都没发现这个子类的实现有什么不妥。直到有人说,父类变了!这时候,我们就想找杯咖啡暖暖手,一个人静静。
面向对象技术确实有它值得傲娇的地方。但是,只有把类似上面的小麻烦解决掉,它的使用才更合理。 比如说,父类做了修改,能不能立即就通知我? 别等到问题出现了,我们还被蒙在鼓里。
Java 注解就可以帮助我们。

什么是 Java 注解

Java 注解是 Java 1.5 引入的一个工具,类似于给代码贴个标签,通过注解可以为代码添加标签信息。这些标签信息可以添加在字段、方法和类上。开发工具、部署工具或者运行类库,可以对这些标签信息进行特殊的处理,从而获得更丰富的功能。
经过十多年的发展,注解已经成了 Java 生态系统一个非常重要的技术。使用注解可以大幅度降低我们的开发强度,提高工作效率,减少潜在的错误。像 Java 类库一样,注解也有了越来越丰富的定义和规范,成了我们需要掌握的重要技术之一。
取消
完成
0/1000字
划线
笔记
复制
© 版权归极客邦科技所有,未经许可不得传播售卖。 页面已增加防盗追踪,如有侵权极客邦将依法追究其法律责任。
该试读文章来自付费专栏《代码精进之路》,如需阅读全部文章,
请订阅文章所属专栏。
立即订阅
登录 后留言

精选留言(19)

  • hua168
    老师,问3个很重要的题外问题:
    1. 大专学历,想直接自学考本科或研究生,自考学历中大型公司承认的吗?
    2. 大公司对年龄有限制的吗?
    3. 30多岁,运维(编程自学java一年,没项目经验),只有小公司工作经验,技术一般,发展方向是什么?很多IT公司好像都不要年龄大点的~~人生80,那不是40岁就没得工作了?

    作者回复: 人生三十,学历的分量应该比重不大了。国内的部分大公司,年龄是个考量的因素,但是也就是众多因素中的一个因素。如果把劳动力看成一个理性的市场,重要的是我们有什么可以拿来交换的。

    我有一个朋友,认识他的人都特别佩服,他曾经兼顾过一段时间的非常枯燥无聊、看起来也没什么技术含量的工作。 过了几年,当他把工作转交给下一个人时,他已经把这项工作做的像一个艺术了。他做了大量的自动化,看起来非常枯燥无聊的事情,被他搞的很有趣,自动化后,根本就占用不了他多长时间。

    软件是一个复杂的系统,需要各种各样的人才,有能研发的,有能测试的,有能运维的,有能运营的。每种都需要不同的技能。再厉害的研发也不一定做得了测试,也不一定做得了运维。

    把你手头的工作做出花来,这就是我们值钱的地方。 怎么才能做出花来呢? 这个你的领导不知道,你的公司可能也不知道,所以大概率没有人能够教你怎么做。你得自己去从工作中发现现实的问题,找到具体的解决办法。多看看新的技术,想一想能不能用到你的工作环境中去。 你可能看到100个技术,只有一个能用。 一个能用,这就行了。你要是不看100个,可能没有办法找到这一个。

    运维就是一个涉及到很多复杂知识的岗位,它的复杂度一点都不必软件开发简单。 但是,的确也有的运维就是看几台机器。但是,既然是你做运维,你可以自己定义运维该怎么做最好。

    不管时哪一个岗位,如果做到一定程度,年龄从来都不是真正的问题。很多岗位,年龄都是优势,而不是问题,因为没有积年累月的积累,我们成不了一个领域最专业的人。成为问题的,是我们40岁了,水平还停留在20到30岁的阶段。

    Stay Hungry, Stay Foolish!

    2019-01-23
    23
  • 岁月安然
    lombok插件的很多实用的注解
    @Data 使用在类上,该注解会提供getter、setter、equals、canEqual、hashCode、toString方法。
    @NonNull 该注解使用在属性上,该注解用于属的非空检查,当放在setter方法的字段上,将生成一个空检查,如果为空,则抛出NullPointerException。
    @AllArgsConstructor 该注解使用在类上,该注解提供一个全参数的构造方法,默认不提供无参构造。
    @NoArgsConstructor 该注解使用在类上,该注解提供一个无参构造。
    等等

    作者回复: 学习了,我还不知道这个插件。注解真的非常强大!

    2019-01-24
    11
  • 王智
    阿里巴巴的扫描插件或许会有帮助的,在使用idea的过程中,安装了Alibaba Java Coding Guidelines之后,代码的规范等等插件就会检测出来报红,虽然可以运行,但是对于有强迫症和代码洁癖的人来说就很难受.
    包括了if不写括号,继承的方法没有使用@Override注解.

    对于刚刚工作的我,java中的注解用的最多的就是@Override了. 废弃方法在idea中会有横线作为标记,有这种标记的方法一律不使用.

    继续加油去了.

    作者回复: 加油!

    2019-01-23
    2
  • 卞雪达
    哈哈哈,最常用的注解,现在都成Spring的@Autowired啦,还有Spring的各种注解,给我的感觉,Spring使用多了,都是注解编程啦,我参数检验都用注解完成。我也会写自己的注解,我刚刚还完成了一个@Excel,我这是个Web的项目,有的接口产生的数据,可能会被导出成Excel,我捣鼓了几波,终于弄了一个注解,放在controller层的方法上,让那种简单的回List的接口,可以直接导出成Excel(配合下http参数),我遇到比较大的麻烦,是我之前设计了一个@Page的注解,注在Service层方法上,帮助开启数据库分页(也要配合http参数,且是一个方法查一次数据的那种),而@Excel跟它有个比较大的冲突:@Page是要分页,@Excel是不要分页。用户肯定是查询的时候看到分页接口,导出的时候拿到全部结果,我得想办法通知一下@Page,我最开始尝试给@Page里面的default方法弄个参数,然后改这个值,后来发现这个值竟然不是每个线程独有的,而是唯一的,也就是改了大家全都改,后来想了想,大概是因为注解本质上是个接口或类似接口?最终选择了ThreadLocal来通知@Page,我已经使用了很多ThreadLoacal了,我之前用它不是很多,现在有些上瘾,又隐隐担心别有坑,比如我知道有个不remove可能有内存溢出的坑。回到注解的话题,注解编程我觉得挺帅的,@Override我也爱加,能给方法加多少注解我就加多少,感觉是一种加持,哈哈哈,不过创造、使用注解就像是创造、使用规则,得对这个规则熟悉,好多注解编译器也不能判断你是不是符合了规则,用的时候还是有些学习成本。

    作者回复: 👍 很多Java的特性,被大家用的出神入化,甚至远远超出了设计者的构想!这真的很帅啊!

    2019-05-15
    1
  • web
    题目有点大, 以为是讲怎么写注解; 内容有点水, 半个版面怎么写override

    作者回复: 😄和规范有关的注解。

    2019-01-28
    1
  • Being
    Override对应C++就是virtual了,经常用,以前还真不太清楚为什么重写的方法要加,就觉得好区别,就保留这个习惯了,今天才意识到要避免父类删除继承方法后,能快速通过编译器定位问题。
    貌似C++没有JAVA的Depraceted和SuppressWarnings类似的,我再查查确认下,Deprecated的用处挺大的,及时止损呀

    作者回复: 谢谢分享C++对应的关键字。

    2019-01-23
    1
  • 啦啦啦
    课程都是以java讲解的吗,没有其他编程语言吗

    作者回复: 除了个别的例子,几乎都是用Java讲解的。

    2019-01-23
    1
  • 苦行僧
    现在基本上是用静态代码检查工具扫描业务代码,jdk中的废弃方法基本替换掉

    作者回复: 赞,这是一个好习惯!

    2019-01-23
    1
  • Sisyphus235
    注解如果没有校检功能就是注释,如果需要校检功能,各个语言都有自己的特色,比如 python 的装饰器,能够极大的提高代码可读性,模块封装的更好。
    是否使用注解应该是个开放话题,注释倒是必须写清楚的。

    作者回复: “是否使用注解应该是个开放话题”,是的,注解很复杂,不同的注解,要分开考量。

    2019-05-22
  • 程龙
    老师 我想问下,接口和实现类,注解应该写在接口 上面还是实现类?

    作者回复: 要区分一下。 一般的,我们说接口是公开的interface或者class。接口的规范(注释的一种形式)要写在接口里,这样自动生成的文档,便于查阅。一般的实现类,是在内部包或者代码里。实现类的注释,是帮助理解实现类的,要贴着代码写。

    2019-04-10
  • 苦行僧
    spring注解才是坑超级多
    2019-03-11
  • 悲劇の輪廻
    虽然只是为了举例而写的代码段,但一般情况下需要被equals的对象为字符串时我们会声明一个字符串常量,而当一个从方法获得的值需要与字符串常量作比较的时候,通常把方法返回值放在被equals的位置,这样也能避免方法返回null时抛出空指针异常,而且不会引起逻辑上的错误。:-)

    作者回复: 只有多次使用时,一般才会考虑定义常量。euqals的使用是一个很好的实践。代码质量就是这些一点一点的小事累积而成的。

    2019-02-25
  • 醉侠
    老师,想知道文章里String的构造函数为什么被移除,是因为字符编码的问题吗?

    作者回复: 是字符编码的问题,这个构造函数(String​(byte[] ascii, int hibyte))没有充分的信息可以把字节(byte)转换成合适的字符(character)。

    2019-02-13
  • 小新是也
    用的最多的应该是Lombox的@Data了
    2019-02-03
  • 小成
    C++11引入了override关键字,对应Java的override.
    C++14引入了deprecated关键字,对应Java的deprecated.

    作者回复: 谢谢分享,这个留言对使用C++的有帮助!

    2019-01-30
  • hua168
    看你介绍,您是DBA大神,有哥们小公司搞DBA几年,会mysql、MSSQL、mongoDB,群集、分库,分表、分区简单优化等,不懂开发,我想问一下:
    1.DBA一般发展方向是怎样的呀?运维和开发我了解,DBA没接触过,无法给建议,一般的升级过程是怎样的?
    2.DBA开发语言选择是C++还是java,还是其它?
    3.以后发展方向是怎样?现在都是开源、大数据时代时代,阿里又搞“去IOE”,一般oracle DBA发展前景不好吧?

    DBA工资普遍比开发、运维高,但感觉很难~~能帮菜鸟指一个大概的方向吗?谢谢~~

    作者回复: 可能是你搞错了,我不懂Oracle的数据库。我的数据库知识也比较陈旧了,还是十多年前的见识,没什么长进。

    小伙伴们帮着回答一下吧!

    2019-01-24
  • hua168
    非常感谢您的认真回答!谢谢……

    作者回复: 不客气

    2019-01-24
  • 多拉格·five
    在项目中使用Lombok可以减少很多重复代码的书写。使用注解在class文件中生成getter/setter/toString等方法。

    作者回复: 了解了。谢谢!

    2019-01-24
  • allean
    Findbugs?

    作者回复: FindBugs/SpotBugds,或者规范的插件,都能检查出来这些问题。

    2019-01-23
收起评论
19
返回
顶部