程序员你为什么这么累?接口定义常见问题

工作中,少不了要定义各种接口,系统集成要定义接口,前后台掉调用也要定义接口。接口定义一定程度上能反应程序员的编程功底。列举一下工作中我发现大家容易出现的问题:

#返回格式不统一

同一个接口,有时候返回数组,有时候返回单个;成功的时候返回对象,失败的时候返回错误信息字符串。工作中有个系统集成就是这样定义的接口,真是辣眼睛。这个对应代码上,返回的类型是map,json,object,都是不应该的。实际工作中,我们会定义一个统一的格式,就是ResultBean,分页的有另外一个PageResultBean

错误范例

返回map可读性不好,不知道里面是什么

@PostMapping("/delete")
public Map<String, Object> delete(long id, String lang) {

}

错误范例

成功返回boolean,失败返回string,大忌

@PostMapping("/delete")
public Object delete(long id, String lang) {
  try {
    boolean result = configService.delete(id, local);
    return result;
  } catch (Exception e) {
    log.error(e);
    return e.toString();
  }
}

#没有考虑失败情况

一开始只考虑成功场景,等后面测试发现有错误情况,怎么办,改接口呗,前后台都改,劳民伤财无用功。

错误范例

不返回任何数据,没有考虑失败场景,容易返工

@PostMapping("/update")
public void update(long id, xxx) {

}

#出现和业务无关的输入参数

如lang语言,当前用户信息 都不应该出现参数里面,应该从当前会话里面获取。后面讲ThreadLocal会说到怎么样去掉。除了代码可读性不好问题外,尤其是参数出现当前用户信息的,这是个严重问题。

错误范例

(当前用户删除数据)参数出现lang和userid,尤其是userid,大忌

@PostMapping("/delete")
public Map<String, Object> delete(long id, String lang, String userId) {

}

#出现复杂的参数

一般情况下,不允许出现例如json字符串这样的参数,这种参数可读性极差。应该定义对应的bean。

错误范例

参数出现json格式,可读性不好,代码也难看

@PostMapping("/update")
public Map<String, Object> update(long id, String jsonStr) {

}

#没有返回应该返回的数据

例如,新增接口一般情况下应该返回新对象的id标识,这需要编程经验。新手定义的时候因为前台没有用就不返回数据或者只返回true,这都是不恰当的。别人要不要是别人的事情,你该返回的还是应该返回。

错误范例

约定俗成,新建应该返回新对象的信息(对象或者ID),只返回boolean容易导致返工

@PostMapping("/add")
public boolean add(xxx) {
  //xxx
  return configService.add();
}

相关讨论

当时在知乎上发帖的时候,有人认为返回给前台的信息应该越少越好,避免出现信息泄露问题。这个觉悟是对的,但对象ID并不是敏感信息,这里返回没有问题。

很多人看了我的这篇文章程序员你为什么这么累?,都觉得里面的技术也很简单,没有什么特别的地方,但是,实现这个代码框架之前,就是要你的接口的统一的格式ResultBean,aop才好做。有些人误解了,我那篇文章说的都不是技术,重点说的是编码习惯工作方式,如果你重点还是放在什么技术上,那我也帮不了你了。同样,如果我后面的关于习惯和规范的帖子,你重点还是放在技术上的话,那是丢了西瓜捡芝麻,有很多贴还是没有任何技术点呢。

晓风轻总结

统一的接口规范,能帮忙规避很多无用的返工修改和可能出现的问题。能使代码可读性更加好,利于进行aop和自动化测试这些额外工作。大家一定要重视。

本文作者:晓风轻
原文链接:https://xwjie.github.io/rule/
版权归作者所有,转载请注明出处


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Java 异常体系是 Java 语言用于处理程序中出现异常情况的一种机制。Java 异常分为两种:检查异常和运行时异常。 检查异常是在程序编译期就可以被发现的异常,它们继承自 Exception 类。在使用可能会抛出检查异常的方法时,编译器会强制要求程序处理这些异常,例如使用 try-catch 块进行捕获和处理,或者向上抛出异常。 运行时异常是在程序运行期间才会发生的异常,它们继承自 RuntimeException 类。在程序编写过程中,不需要进行捕获和处理。运行时异常通常是由于程序错误导致的,例如数组下标越界、空指针引用等。 常见的运行时异常包括: 1. NullPointerException:空指针异常,当一个变量为 null 值时,如果调用它的方法或属性,就会抛出此异常。 2. IndexOutOfBoundsException:下标越界异常,当程序尝试访问数组或字符串的不存在的索引时,就会抛出此异常。 3. IllegalArgumentException:非法参数异常,当传递给一个方法的参数不符合方法的要求时,就会抛出此异常。 4. ArithmeticException:算术异常,当在做除法运算时除数为零时,就会抛出此异常。 5. ClassCastException:类转换异常,当程序试图将一个对象强制转换为不是其子类的类型时,就会抛出此异常。 ### 回答2: Java 异常体系是一种用于处理程序运行时错误的机制,它将错误分为两种类型:可检查异常和不可检查异常。 可检查异常是指程序必须显式处理的异常,即使用 try-catch 块进行捕获和处理,或者在方法声明中使用 throws 关键字抛出。这些异常一般是程序出现问题时可以纠正的错误,例如输入输出异常(IOException)、空指针异常(NullPointerException)等。 不可检查异常是指程序可以选择处理,但没有强制要求的异常,通常是由程序员的逻辑错误导致。例如算术异常(ArithmeticException)、数组索引超出界限异常(ArrayIndexOutOfBoundsExceptio)等。不可检查异常也可以捕获和处理,但是一般情况下更多的是通过编码和测试来避免这些错误的发生。 常见的运行时异常包括:空指针异常(NullPointerException)、类转换异常(ClassCastException)、数组索引越界异常(ArrayIndexOutOfBoundsException)等。这些异常在程序运行时可能会出现,但是可以通过编码和测试来避免它们的发生。 总之,Java 异常体系提供了一种机制来处理程序运行时错误,异常之间的区别在于是否需要显式处理,以及它们的发生是由程序错误还是外部条件引起的。开发者可以根据异常的类型来决定如何处理它们,从而提高程序的可靠性和健壮性。 ### 回答3: Java 异常体系是一套用于处理程序错误和异常情况的机制。它定义了一组异常类和接口,使程序员可以在程序执行过程中对异常进行捕获、处理和抛出。 在 Java 异常体系中,异常类分为两大类:可检查异常和运行时异常。可检查异常是指程序在编译时必须处理的异常,如果不处理将无法通过编译;而运行时异常则是指程序在运行过程中可能会遇到的异常,程序员可以选择处理或者忽略这些异常。 常见的运行时异常有: 1. NullPointerException(空指针异常):当程序试图在一个引用类型的变量上调用方法或访问属性时,该变量的值为 null,导致空指针异常。 2. ArrayIndexOutOfBoundsException(数组下标越界异常):当程序试图访问数组中不存在的索引位置时,导致数组下标越界异常。 3. IllegalArgumentException(非法参数异常):当方法接收到一个不合法的参数时,会抛出非法参数异常。 4. ClassCastException(类转换异常):当程序试图将一个对象强制转换为与其类型不兼容的类时,导致类转换异常。 5. ArithmeticException(算术异常):当程序执行整数除法或取余操作时,除数为0会导致算术异常。 总之,Java 异常体系提供了一种有效的方法来处理程序中的错误和异常情况。程序员可以根据具体情况选择处理或者忽略异常,并且合理地使用异常机制可以提高程序的可靠性和可维护性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值