看完这篇文章获得一些java if优化技巧

目录
  • 1、if 合并
  • 2、将正常的流程放在函数的主干执行
  • 3、减少if
    • 1. 使用三元运算符表达式
    • 2.使用java8 中流过滤filter ,不使用if
    • 3、使用枚举
    • 4、使用manager
    • 5、使用Consumer
  • 总结:

1、if 合并

使用逻辑运算符进行合并if。简单的if 嵌套可以使用&& 进行合并。简单的if else 并且操作相同可以使用 || 进行合并,优化代码逻辑,增加可读性。

注意:逻辑运算符的截断性,if(a >= 10 || b >= 20) 当a>= 10 成立时 是不会判断后面的,只要条件成立,则if 判断结束。

因此简单判断放在最前面,在开发的过程中,将简单的逻辑判断前置,减少判断的次数,可以提高性能,提高性能!

2、将正常的流程放在函数的主干执行

在开发中有些同学会跟着策划写逻辑,将策划的功能描述进行直接转码,造成了很多判断的嵌套。

在这时可以将代码逻辑进行整理,先进行check ,各种不符合条件的判断提前判断并结束函数,最基本的原则就是:将最后的主逻辑留在函数的主干内。

比如下面的场景:玩家需要达到等级100,并且拥有足够的体力,才能够参与活动,否则的话则报错误码。

可以看到 主逻辑 doSomeThing 在第一处的时候if的嵌套层数是2层,在第二处的时候 嵌套层数 是0 层。在阅读的代码的时候,可以直接顺序读下去,将不太需要关注的分支跳过即可,可读性有了优化,代码更优雅。

3、减少if

1. 使用三元运算符表达式

比如在战斗的时候,需要根据玩家的等级进行战斗力的放大,所有有下面的代码,可以看到用三元运算符代码行数较少,而且逼格显然比较高。

2.使用java8 中流过滤filter ,不使用if

在开发的过程中需要过滤某一个类型的道具,在背包内查找满足需要的道具。

下面的代码传入需要过滤的道具类型,然后在第一处的地方模拟了背包的数据,

第二处是使用if的过滤。

第三处是使用stream 进行过滤,可以看到使用java8 避免了使用if判断,函数式的接口,优雅并且易于理解。

3、使用枚举

枚举是我们项目里用的很多的一种解决办法,比如我们的资源管理,任务管理,组队管理等等功能,都是使用了枚举解决if else 问题,当你面对的一个同样的问题,只是因为类型的不同的时候,则可以使用枚举进行优化代码。

下面的枚举定义了一个抽象方法,由每个枚举单独实现。

在使用的时候可以直接使用对应的枚举进行操作,不需要使用if 进行操作,是不是很方便?同时在以后扩展的时候只要增加枚举,不需要修改原来的代码?降低了出bug的风险。

4、使用manager

同样的问题,也可以使用manager进行解决,思路就是将对应类型的处理类先进行注册,等用的时候直接从map中获取,然后使用,避免了if 的判断。

比如上期的资源系统,就是使用了manager 进行的处理。在游戏启动的时候注册了每种资源的处理类,所有的资源类都继承了同样的接口,在使用的时候可以直接调用相同的接口,这样就没必要尽心if 判断。

5、使用Consumer

比如战斗的时候,需要根据战斗的类型不同,然后有不同的处理函数,在这时候可以使用Consumer,将每个单独的类型单独处理。避免了使用if

总结:

if 很简单,但是也有一些技巧。毕竟编程语言的创造者创造简单的if,for 就表示了这世界所有的逻辑。用好if,增加代码可读性,让自己的代码更优雅,Bug 更少。

本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注我们的更多内容!

(0)

相关推荐

  • java策略枚举:消除在项目里大批量使用if-else的优雅姿势

    想起刚开始接触JAVA面向对象编程时,若遇到大量流程判断语句,几乎满屏都是if-else语句,多得让自己都忘了哪里是头,哪里是尾,但是,纵然满屏是if-else,但彼时也没有觉得多别扭.等到编程能力渐渐提升之后,再回过头去看曾经写过的满屏if-else时,脑海里只有一个画面,全都是翔..... 可能初学者都会忽略掉一点,其实if-else是一种面向过程的实现. 那么,如何避免在面向对象编程里大量使用if-else呢? 网络上有很多解决思路,有工厂模式.策略模式.甚至是规则引擎(这个太重了吧)..

  • 分析java并发中的wait notify notifyAll

    一.前言 java 面试是否有被问到过,sleep 和 wait 方法的区别,关于这个问题其实不用多说,大多数人都能回答出最主要的两点区别: sleep 是线程的方法, wait / notify / notifyAll 是 Object 类的方法: sleep 不会释放当前线程持有的锁,到时间后程序会继续执行,wait 会释放线程持有的锁并挂起,直到通过 notify 或者 notifyAll 重新获得锁. 另外还有一些参数.异常等区别,不细说了.本文重点记录一下 wait / notify

  • Java流程控制语句之If选择结构

    一.选择结构大纲 if单选择结构 if双选择结构 if多选择结构 嵌套的if结构 switch多选择结构 二.if单选择结构 我们很多时候需要去判断一个东西是否可行,然后我们才去执行,这样一个过程在程序中用if语句来表示 语法: if(布尔表达式) { //如果布尔表达式为true将执行的语句 } 三.if双选择结构 那现在有个需求,公司要收购一个软件,成功了,给人支付100万元,失败了,自己找人开发.这样的需求用一个if就搞不定了,我们需要有两个判断,需要一个双选择结构,所以就有了if-els

  • 如何避免在Java项目里大批量使用if-else?

    避免大批量使用if-else 可能初学者都会忽略掉一点,其实if-else是一种面向过程的实现. 那么,如何避免在面向对象编程里大量使用if-else呢? 网络上有很多解决思路,有工厂模式.策略模式.甚至是规则引擎(这个太重了吧)...... 这些,都有一个共同的缺点,使用起来还是过于繁重了.虽说避免出现过多的if-else,但是,却会增加很多额外的类,我总觉得,很不实用,只能当做某种模式的学习即可. 可以替换大量的if-else语句,且具备较好的可读性与扩展性,同时能显得轻量化,我比较推荐使用

  • Java编程技巧:if-else优化实践总结归纳

    目录 一.使用策略枚举来优化if-else 二.使用三目运算符来优化if-else 1.根据if-else条件来判断赋值的,如: 2.利用if-else条件来判断调用方法,如: 三.使用Stream优化if中判断条件过多情况 四.使用Map优化if-else 五.使用枚举优化if-else 六.使用Optional类优化if-else 总结 一.使用策略枚举来优化if-else 看到网上蛮多人推荐使用策略模式来优化if-else,但我总觉得,搞一堆策略类来优化大批量if-else,虽然想法很好,

  • 看完这篇文章获得一些java if优化技巧

    目录 1.if 合并 2.将正常的流程放在函数的主干执行 3.减少if 1. 使用三元运算符表达式 2.使用java8 中流过滤filter ,不使用if 3.使用枚举 4.使用manager 5.使用Consumer 总结: 1.if 合并 使用逻辑运算符进行合并if.简单的if 嵌套可以使用&& 进行合并.简单的if else 并且操作相同可以使用 || 进行合并,优化代码逻辑,增加可读性. 注意:逻辑运算符的截断性,if(a >= 10 || b >= 20) 当a>

  • Java中你真的会用Constructor构造器吗之看完本篇你就真的会了

    引言 相信大家对于java里的构造器应该都是有了解的,这次我们来了解一些构造器的不同使用方式,了解构造器的调用顺序,最后可以灵活的在各种情况下定义使用构造器,进一步优化我们的代码: 构造器简介 还是简单介绍一下构造器到底是什么吧, 构造器是类中一种特殊的方法,通过调用构造器来完成对象的创建,以及对象属性的初始化操作. 构造器定义方式: [修饰符列表] 构造器名(形式参数列表){ 构造方法体; } 构造器有以下几个特点: 构造器名和类名一致: 构造器用来创建对象,以及完成属性初始化操作: 构造器返

  • 你了解C#的协变和逆变吗,看完这篇就懂了

    从C# 4.0开始,泛型接口和泛型委托都支持协变和逆变,由于历史原因,数组也支持协变. 里氏替换原则:任何基类可以出现的地方,子类一定可以出现. 协变(out) 协变:即自然的变化,遵循里氏替换原则,表现在代码上则是任何基类都可以被其子类赋值,如Animal = Dog.Animal = Cat 使用out关键字声明(注意和方法中修饰参数的out含义不同) 被标记的参数类型只能作为方法的返回值(包括只读属性) 在没有协变时: abstract class Animal {} class Dog

  • 分布式锁为什么要选择Zookeeper而不是Redis?看完这篇你就明白了

    在分布式的应用中,为了防止单点故障,保障高可用,通常会采用主从结构,当主节点挂掉后,从节点可以代替主节点提供服务. Redis通过复制 + sentinel哨兵来实现主从模式. Zookeeper通过replicated mode复制模式来实现主从模式. 单从结构上看,Redis和Zookeeper都是主从架构,那Zookeeper的优势是什么?为什么要选择Zookeeper?难道只是因为Zookeeper是目录结构,Redis是K-V结构吗? 同步机制的不同 Redis Redis在给从节点同

  • 程序员最实用的 SQL 语句收藏,看完这篇就够了

    前言 文章沿着设计一个假想的应用 awesome_app 为主线,从零创建修改数据库,表格,字段属性,索引,字符集,默认值,自增,增删改查,多表查询,内置函数等实用 SQL 语句.收藏此文,告别零散又低效地搜索经常使用的 SQL 语句.所有 SQL 都在 MySQL 下通过验证,可留着日后回顾参考,也可跟着动手一起做,如果未安装 MySQL 可参考 <macOS 安装 mysql> (windows 安装大同小异). 1. 创建 1.1 创建数据库 语法:create database db_

  • Java性能优化技巧汇总

    本文实例汇总了Java性能优化技巧.分享给大家供大家参考.具体分析如下: 这里参考了些书籍,网络资源整理出来,适合于大多数Java应用 在JAVA程序中,性能问题的大部分原因并不在于JAVA语言,而是程序本身.养成良好的编码习惯非常重要,能够显著地提升程序性能. 1.尽量使用final修饰符. 带有final修饰符的类是不可派生的.在JAVA核心API中,有许多应用final的例子,例如java.lang.String.为String类指定final防止了使用者覆盖length()方法.另外,如

  • vue3自定义指令看完这篇就入门了

    目录 前言 1. 什么是自定义指令 2. 声明私有自定义指令的语法 3. 使用自定义指令 4. 声明全局自定义指令的语法 5. updated 函数 6. 函数简写 7. 指令的参数值 附:下面根据自定义指令知识点衍生的一个小例子 总结 前言 这篇文章介绍vue组件中的自定义指令!看完不会你打我.哈哈哈,开玩笑的!! 1. 什么是自定义指令 vue 官方提供了 v-for.v-model.v-if 等常用的内置指令.除此之外 vue 还允许开发者自定义指令. vue 中的自定义指令分为两类,分别

  • Javascript优化技巧(文件瘦身篇)

    最近一直在研究 Javascript 相关的技术.在<Javascript 高级程序设计>有篇章节着重阐述了优化 Javascript 代码的重要性.相信有很多的 Javascript 开发人员在开发的同时或多或少的会接触到此类的问题. 在大部分情况下,代码的优化并不是实际开发中所需要着重的部分.但是一旦代码完成了以后,开发者总是期待自己的代码能够越短越高效越好.结合从书中获得的知识以及本人实际开发过程中的经验,下面说明本人所采取的一些花招(也算是照本宣科一下). 前言 相比脚本语言,编译型的

  • Java中synchronized 的4个优化技巧

    目录 前言 1.锁膨胀 2.锁消除 3.锁粗化 4.自适应自旋锁 总结 前言 synchronized 在 JDK 1.5 时性能是比较低的,然而在后续的版本中经过各种优化迭代,它的性能也得到了前所未有的提升,上一篇文章我们谈到了锁膨胀对 synchronized 性能的提升,然而它也只是“众多” synchronized 性能优化方案中的一种,那么我们本文就来盘点一下 synchronized 的核心优化方案. synchronized 核心优化方案主要包含以下 4 个: 锁膨胀 锁消除 锁粗

  • Springboot 整合RabbitMq(用心看完这一篇就够了)

    该篇文章内容较多,包括有rabbitMq相关的一些简单理论介绍,provider消息推送实例,consumer消息消费实例,Direct.Topic.Fanout的使用,消息回调.手动确认等. (但是关于rabbitMq的安装,就不介绍了) 在安装完rabbitMq后,输入http://ip:15672/ ,是可以看到一个简单后台管理界面的. 在这个界面里面我们可以做些什么? 可以手动创建虚拟host,创建用户,分配权限,创建交换机,创建队列等等,还有查看队列消息,消费效率,推送效率等等. 以上

随机推荐