首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Java代码评审歪诗!让你写出更加优秀的代码!

贾言 代码评审歪诗 窗外风雪再大 也有我陪伴着你 全文字数:2000字 阅读时间:5分钟 贾言 代码评审歪诗 验幻空越重 命频异长 依轮线日简 接偶正分壮 架构师说, 用20个字描述代码评审的内容...幻-欢 在代码中要杜绝幻数,幻数可定义为枚举或常量以增强其可读性; 空-空 要时刻警惕空指针异常: 常见的 a.equals(b) 要把常量放到左侧; aInteger == 10 如果 aInteger...为空时会抛出空指针异常; 不确认返回集合是否可为空时要做非空判断, 再做for循环; 使用空对象模式,约定返回空集合,而非null; 使用StringUtils判断字符串非空; 越-月 如果方法传入数组下标作为参数...-勋 不要在循环中调用服务,不要在循环中做数据库等跨网络操作; 频-品 写每一个方法时都要知道这个方法的调用频率,一天多少,一分多少,一秒多少,峰值可能达到多少,调用频率高的一定要考虑性能指标,考虑是否会打垮数据库...,是否会击穿缓存; 异-宜 异常处理是程序员最基本的素质,不要处处捕获异常,对于捕获了只写日志,没有任何处理的catch要问一问自己,这样吃掉异常,是否合理; 下面是一个反例, 在导出文件的controller

5.4K20

【算法题】从0培养算法思想——双指针

指针 常⻅的双指针有两种形式,⼀种是对撞指针,⼀种是左右指针。 对撞指针:⼀般⽤于顺序结构中,也称左右指针。 • 对撞指针从两端向中间移动。...• 对撞指针的终⽌条件⼀般是两个指针相遇或者错开(也可能在循环内部找到结果直接跳出 环),也就是: ◦ left == right (两个指针指向同⼀个位置) ◦ left...> right (两个指针错开) 快慢指针:⼜称为⻳兔赛跑算法,其基本思想就是使⽤两个移动速度不同的指针在数组或链表等序列结构上移动。...这种⽅法对于处理环形链表或数组⾮常有⽤。 其实不单单是环形链表或者是数组,如果我们要研究的问题出现循环往复的情况时,均可考虑使⽤快 慢指针的思想。...快慢指针的实现⽅式有很多种,最常⽤的⼀种就是: • 在⼀次循环中,每次让慢的指针向后移动⼀位,⽽快的指针往后移动两位,实现⼀快⼀慢。

6110
您找到你想要的搜索结果了吗?
是的
没有找到

京东资深架构师代码评审歪诗

贾言验幻空越重, 命频异长。 依轮线日简, 接偶正分壮。言欢空月虫, 明勋品宜昌。 依伦先日贱, 洁偶正粉妆。 贾言 架构师说, 用20个字描述代码评审的内容, 自省也省人。...在接口中也明确使用验证注解修饰参数和返回值, 作为一种协议要求调用方按验证注解约束传参, 返回值验证注解约束提供方按注解要求返回参数 幻: 在代码中要杜绝幻数,幻数可定义为枚举或常量以增强其可读性 空: 要时刻警惕空指针异常...常见的 a.equals(b) 要把常量放到左侧 aInteger == 10 如果 aInteger 为空时会抛出空指针异常 不确认返回集合是否可为空时要做非空判断, 再做for循环 使用空对象模式...: 不要在循环中调用服务,不要在循环中做数据库等跨网络操作 频: 写每一个方法时都要知道这个方法的调用频率,一天多少,一分多少,一秒多少,峰值可能达到多少,调用频率高的一定要考虑性能指标,...考虑是否会打垮数据库,是否会击穿缓存 异: 异常处理是程序员最基本的素质,不要处处捕获异常,对于捕获了只写日志,没有任何处理的 catch 要问一问自己,这样吃掉异常,是否合理 下面是一个反例, 在导出文件的

4.7K30

常见负载均衡策略「建议收藏」

负载均衡构建在原有网络结构之上,它提供了一种透明且廉价有效的方法扩展服务器和网络设备的带宽、加强网络数据处理能力、增加吞吐量、提高网络的可用性和灵活性。...基于这个前提,轮调度是一个简单而有效的分配请求的方式。然而对于服务器不同的情况,选择这种方式就意味着能力比较弱的服务器也会在下一轮循环中接受轮,即使这个服务器已经不能再处理当前这个请求了。...管理员只是简单的通过服务器的处理能力来定义各台服务器的权重。例如,能力最强的服务器 A 给的权重是 100,同时能力最低的服务器给的权重是 50。...加权响应 Weighted Response: 流量的调度是通过加权轮方式。加权轮中 所使用的权重 是根据服务器有效性检测的响应时间来计算。...发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

6.5K30

嵌入式开发既要代码小,又要速度快!程序该如何优化?

一、程序结构的优化 1、程序的书写结构 虽然书写格式并不会影响生成的代码质量,但是在实际编写程序时还是应该尊一定的书写规则,一个书写清晰、明了的程序,有利于以后的维护。...因此,应尽量当采用预处理命令方式来定义常数,而且还可以避免输入错误。 5、减少判断语句 能够使用条件编译(ifdef)的地方就使用条件编译而不使用if 语句,有利于减少编译生成的代码的长度。...数组与指针具有十分密切的关系,一般来说指针比较灵活简洁,而数组则比较直观,容易理解。对于大部分分的编译器,使用指针比使用数组生成的代码更短,执行效率更高。...但是在Keil 中则相反,使用数组比使用的指针生成的代码更短。...但是在循环中有通过循环变量“i”读写数组的指令时,使用预减循环时有可能使数组超界,要引起注意。

1.5K30

异步,同步,阻塞,非阻塞程序的实现

如果是同步,线程会等待接受函数的返回值(或者轮函数结果,直到查出它的返回状态和返回值)。如果是异步,线程不需要做任何处理,在函数执行完毕后会推送通知或者调用回调函数。...线程在同步调用下,也能非阻塞(同步轮非阻塞函数的状态),在异步下,也能阻塞(调用一个阻塞函数,然后在函数中调用回调,虽然没有什么意义)。 下面,我会慢慢实现一个异步非阻塞的sleep。...上面的代码中,在一个while循环中timer的状态。由于timer存在于wait中。所以需要把timer“提取”出来。...又因为,没有使用多线程,所以必须自己实现一些简单的调度处理,也就是说,要能自由的切换各个timer的上下文。在单线程下可以使用yield。 1....也就是说,在每个要处理阻塞的地方,都人为的把函数切成三个部分: 1. 执行函数前半部 2. 执行新线程,把后半部作为回调函数传入。函数退出。 3. 等待后半部在线程完毕后被执行。

7.5K10

负载均衡调度算法大全

基于这个前提,轮调度是一个简单而有效的分配请求的方式。然而对于服务器不同的情况,选择这种方式就意味着能力比较弱的服务器也会在下一轮循环中接受轮,即使这个服务器已经不能再处理当前这个请求了。...image 加权轮(Weighted Round Robin) 这种算法解决了简单轮调度算法的缺点:传入的请求按顺序被分配到集群中服务器,但是会考虑提前为每台服务器分配的权重。...管理员只是简单的通过服务器的处理能力来定义各台服务器的权重。例如,能力最强的服务器A给的权重是100,同时能力最低的服务器给的权重是50。...和加权轮调度方法一样,不正确的分配可以被记录下来使得可以有效的为不同服务器分配不同的权重。...加权响应(Weighted Response) 流量的调度是通过加权轮方式。加权轮中所使用的权重是根据服务器有效性检测的响应时间来计算。每个有效性检测都会被计时,用来标记它响应成功花了多长时间。

6.3K30

【C++】STL 算法 ② ( foreach 循环中传入 函数对象 Lambda 表达式处理元素 | foreach 循环算法 | Lambda 表达式 - 匿名 函数对象 仿函数 )

文章目录 一、foreach 循环中传入 函数对象 / Lambda 表达式处理元素 1、foreach 循环算法 2、foreach 循环中传入 函数对象 处理元素 3、foreach 循环中传入 Lambda...表达式 处理元素 4、Lambda 表达式 - 匿名 函数对象 / 仿函数 一、foreach 循环中传入 函数对象 / Lambda 表达式处理元素 1、foreach 循环算法 在 C++ 语言中...循环 虽然 不是标准库的一部分 , 但是 C ++ 编译器 提供了对 该语法 的支持作为扩展 ; 使用 该 std::foreach 循环 , 可以用于 遍历 STL 标准模板库 中提供的容器 , ...: 函数 / 函数指针 / 仿函数 / 函数对象 / Lambda 表达式 , 并对范围内的每个元素调用该可调用对象 ; 注意 : 上述 迭代器 范围 是一个 前闭后开 区间 ; 2、foreach 循环中传入...Lambda 表达式 处理元素 在下面的 foreach 循环中 , 传入了 Lambda 表达式 , 该 Lambda 表达式实现的效果 [](int num) { std::cout << num

12210

Go的逃逸分析及优化

解决方案可以通过一以下一些方法来优化内存逃逸,以提高程序的性能和内存利用效率: 减少不必要的指针和引用:尽量减少不必要的指针和引用,避免将变量的引用传递到函数外部,从而减少内存逃逸的可能性。...尽量避免在函数内部定义闭包,并且在循环中使用闭包时要格外小心。 使用栈分配:尽可能地使用栈分配而不是堆分配,可以减少内存逃逸的发生。...string}func createUser(id int, name string) User { return User{ID: id, Name: name} // 避免返回指向局部变量的指针...临时变量优化以下是一个示例,演示了如何在函数内部避免创建大型的临时变量,从而减少内存逃逸:package mainfunc generateData() []int { data := make(...因此,在开发中,了解并优化内存逃逸并通过采取一系列的措施,合理地分配和释放内存资源、避免在循环中分配和释放内存、使用垃圾回收机制等,可以有效地避免内存逃逸的发生,提高程序的性能和可靠性。

12820

【Rust日报】2020-05-18 Castor, WASM, Rust嵌套循环

来让循环变得更加强大,甚至可以达到Go语言的复杂格式的循环: for i := 0; i < 10; i++ { fmt.Println(i) } Rust语言的循环没有说明iteration(i++)的每一个指针步增时候的情况..., 也没有说明如何在(i<10)前如果步进到下一步,仅仅是让iterator走完。...("{}", x); } 关键词continue都是跟所有语言一样,在这个例子中当x>5并且x<7的时候在循环中continue到下一个iteration中而不打印,这样结果是: 0 1 2 3 4...("{}", x); } 打印结果: 0 1 2 3 4 5 嵌套循环: 在很多编程语言,嵌套循环都非常诡异,比如,我们如何在一个嵌套循环中让外循环继续的条件建立在内循环里呢?...缺省的中断就是直接从内循环中断出来,利用标签的方式,也可以用来实现循环继续。

80020

四层和七层负载均衡的特点及常用负载均衡Nginx、Haproxy、LVS对比

四层负载均衡只能根据报文中目标地址和源地址对请求进行转发,而无法修改或判断所请求资源的具体类型,然后经过负载均衡内部的调度算法转发至要处理请求的服务器。...常用负载均衡软件对比 LVS 1、抗负载能力强、性能高,能达到 F5 硬件的 60%;对内存和 cpu 资源消耗比较低 2、工作在网络4层,通过 vrrp 协议转发(仅作分发之用),具体的流量由 linux 内核处理...2、稳定性、可靠性好,自身有完美的热备方案;(:LVS + Keepalived) 3、应用范围比较广,工作在四层,所以不用考虑要处理的具体应用,可以对所有应用做负载均衡; 4、不支持正则处理,不能做动静分离...5、支持负载均衡算法:rr(轮)、wrr(带权轮)、lc(最小连接)、wlc(权重最小连接) 6、配置复杂,对网络依赖比较大,稳定性很高。...安装和配置比较简单,测试起来比较方便; 4、也可以承担高的负载压力且稳定,一般能支撑超过1万次的并发; 5、对后端服务器的健康检查,只支持通过端口来检测,不支持通过url来检测; 6、Nginx 对请求的异步处理可以帮助节点服务器减轻负载

2.2K30

【书单】18本数据科学家必读的R语言和Python相关书籍

它并没有对概念进行理论解释,而重点介绍如何在 R 中使用它们。本书涵盖了广泛的主题,概率,统计,时间序列分析,数据预处理等。 ?...本书不仅仅具有理论知识,而且强调如何在 R 中构建样本数据集。同时专注使用 ggplot2 包来进行可视化。 ?...但是,不能期望从本书中学习到高级机器学习概念,堆叠。 ?...本书内容详实,涵盖了通过 Python 进行数据分析的各方面内容,:操作,处理,清理,可视化和处理数据等。如果你是使用 Python 进行数据科学的新手,那么本书不可错过。 ?...Learning Systems with Python 作者:Willi Richert , Luis Pedro Coelho 译者:刘峰 在本书,作者先从基础开始,接着通过项目解释概念,最终附上总结,渐进

2.7K90

三大主流软件负载均衡器对比(LVS VS Nginx VS Haproxy)(转)

2、稳定性、可靠性好,自身有完美的热备方案;(:LVS+Keepalived) 3、应用范围比较广,可以对所有应用做负载均衡; 4、不支持正则处理,不能做动静分离。...5、支持负载均衡算法:rr(轮)、wrr(带权轮)、lc(最小连接)、wlc(权重最小连接) 6、配置 复杂,对网络依赖比较大,稳定性很高。...、对Big request header的支持不是很好, 9、支持负载均衡算法:Round-robin(轮)、Weight-round-robin(带权轮)、Ip-hash(Ip哈希) 10、Nginx...9、支持负载均衡算法:Round-robin(轮)、Weight-round-robin(带权轮)、source(原地址保持)、RI(请求URL)、rdp-cookie(根据cookie) 10、...衡量负载均衡器好坏的几个重要因素:  1、会话率 :单位时间内的处理的请求数  2、会话并发能力:并发处理能力  3、数据率:处理数据能力  经过官方测试统计,haproxy 单位时间处理的最大请求数为

1.9K10

常见编程模式之快慢指针

这种方法对于处理「环形」链表或数组非常有用。以链表为例,通过以不同的速度移动,我们可以证明如果链表中存在环,则两个指针必定会相遇,当两个指针均处在环中时,快指针会追上慢指针(如下图所示)。 ?...在以下场景中,我们可能会用到快慢指针: 题目涉及包含「循环」的链表或数组 需要求解链表中某个元素的位置或链表长度 快慢指针和双指针比较类似(可以理解为特殊的双指针法),在只能单向移动的数据结构中(单向链表...),一般使用快慢指针判断回文链表(Leetcode 234)。...,则下一步快指针移动两格,慢指针移动一格,两者相遇; 如果快指针在慢指针后两格,则下一步后快指针在慢指针后一格,回到第一种情况,两者可以相遇 如果快指针在慢指针后 N 格,则下一步后快指针在慢指针后 N...此外,一个循环中的所有运动都必须沿着同一方向进行。换句话说,一个循环中不能同时包括向前的运动和向后的运动。

4.4K30

JAVA语言程序设计(一)04747

:100、200、0、-250 浮点数常量:直接写上的数字 ,有小数点。列:2.5、-3.14 字符常量:凡是用单引号引起来的单个字符,叫做字符常量。**注意:只能写一个,且不能不写。...自动类型转换(隐式) 代码不需要特殊处理,自动完成。...列“+” 表达式:用运算符连起来的式子叫做表达式。列:20+5. 、a+b 算术运算符 / 【 】 取mode:% 只有对于整数的除法来说,取模运算符才有余数的意义。...,一般可以分成四部分 初始化语句:在坏开始最初执行,而且只做唯一一次 条件判断:如果成立,则坏继续,不成立坏退出 坏体:重复做的事情内容,若干行语句 步进语句:每次坏之后要进行的扫尾工作,每次坏结束都要这样...for坏 while坏 标准格式 while(条件判断){ 坏体 } 先执行初始表达式,看布尔表达式,满足就执行坏体跟步进表达式 do while 初始化语句

5.1K20

android6.0系统Healthd深入分析

代码中开始便是解析参数,healthd_mode_ops是一个关于充电状态结构体变量,结构体变量里的参数是函数指针,在初始化时指向各个不同的操作函数,当开机充电时变量赋值为&android_ops,关机充电时候变量赋值为...android_ops的init函数指针指向healthd_mode_android_init函数 代码如下: void healthd_mode_android_init(struct healthd_config...nevents 表示从epollfd中轮中监听得到的事件数目,这里介绍一下轮询机制中重要函数epoll_waite(). epoll_wait运行的道理是:等侍注册在epfd上的socket fd的事务的产生...事件处理主要在for循环中: 在periodic_chores()中调用到healthd_battery_update()更新电池状态。...在for循环中处理,for循环中代码看起来非常难懂,其实if判断的便是event有没有相应的处理函数,在前面注册事件时候已经提到,三种句柄上的事件都有对应的处理函数,也就是当收到gBinderfd上的事件

1.6K10

C语言代码优化的一些经验及小技巧(三)

如果循环迭代次数只有几次,那么可以完全展开循环,以便消除坏带来的负担。...else { } 此处,若condition为1的概率大较大则把if (1 == condition)放在前面,若condition为2概率大较大则把if (2 == condition)放在前面,:...condition) { } else if (1 == condition) { } else { } 这里有个小细节:在用if判断某个变量与某个常量是否相等时,可以把常量写在前面变量写在后面,:...使用位运算替代四则运算 在许多古老的微处理器上, 位运算比加减运算略快, 通常位运算比乘除法运算要快很多。在现代架构中, 位运算的运算速度通常与加法运算相同,但仍然快于乘法运算。...尽量使循环体内的工作量达到最小化 循环中,随着循环次数的增加,会加大对系统资源的消耗。我们应当确认一些操作是否必须放在循环体内。

2.2K21

寻找链表中环的入口节点

环中有4个节点,那么 将p1指针在链表上向前移动4步 p1、p2指针以相同的速度在链表上向前移动 它们相遇的节点正好是环的入口节点 IMG_66D663B2FE91-1 获取环中节点数量 通过上个章节的分析...,我们知道了只要能得到环中的节点数量,就可以找到环的入口节点。...p1、p2指针指向判断链表中有环时的相遇节点 p1指针继续向前移动,边移动边计数 p1指针与p2指针再次相遇时,即可得到环中节点数量 IMG_584FEB598A64-1 实现代码 通过上面的分析,我们已经得到了解决问题的思路...若p1指针走到链表尾部都没有与p2指针相遇,那么链表中就不包含环 链表中有环,则做进一步的处理,获取环的入口节点 取出上一步得到的总数量,向前移动p1指针总数量步 p1指针移动完毕后,重置p2指针的指向...变量所记录的值就是环中节点总数量 获取环中节点总数量 寻找环的入口节点 // 寻找环的入口节点 findRingEntranceNode(): ListNode | null { //

83020

Go语言中容易疏忽的重要知识点与相关技巧(1)

指针与值类型的区别 在Go语言中,结构体、数组和切片是值类型,而不是引用类型。这意味着将它们作为参数传递给函数时,会进行值的拷贝,而不是传递指针。这可能导致性能问题和意外的行为。...正确使用WaitGroup需要仔细处理,确保正确的计数和等待。 3. 错误处理与错误链 Go语言的错误处理机制非常重要,但在实际开发中经常被忽视。...4. defer关键字的执行顺序 defer关键字用于在函数返回之前执行某个操作,资源清理。但要注意defer语句的执行顺序,特别是当defer语句中涉及到函数参数和闭包时。...7. defer和匿名函数的陷阱 在使用defer时,特别要注意在循环中使用匿名函数的情况。在循环中注册的defer语句执行时,可能会捕获到循环变量的不正确值,导致意外的结果。...本文探讨了指针与值类型的区别、sync.WaitGroup的正确使用、错误处理与错误链、defer关键字的执行顺序、切片和数组的容量问题、字符串的不可变性以及defer和匿名函数的陷阱。

15020
领券