@RequiresApi(api = Build.VERSION_CODES.O)
对于代码
// 格式化日期为MySQL的DATE类型格式
private String formatDate(LocalDate date) {
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd");
return date.format(formatter);
}
ofPattern
与format
方法给出红色下划线:
Call requires API level 26 (current min is 21): java.time.format.DateTimeFormatter#ofPattern
具体内容如下图所示:
光标移至爆红处,Alt+Enter(报错解决提示),回车(对于给出的提示栏选择首个)。
具体操作如下图所示:
即在方法实现头处进行加添如下注释:
@RequiresApi(api = Build.VERSION_CODES.O)
java.time包是在 Android API 级别 26(Oreo)引入的,而笔者的 minSdkVersion 设置在 API 级别 21(Lollipop)。
由于在低于 API 级别 26 的设备上,java.time 包是不可用的,因此在这些设备上使用相关的类和方法会导致编译错误或运行时异常。
通过在方法或类上添加@RequiresApi(api = Build.VERSION_CODES.O)注解,笔者在编写代码时就标记了这部分代码需要在 API 级别 26 或更高版本上运行。这样,编译器就会在编译时检查,如果你的 minSdkVersion 低于 26,就会给出警告或错误,提醒开发者潜在的兼容性问题。
在笔者的解决方案中,通过在方法上添加注解,告诉编译器:这个方法使用了 API 级别 26 引入的新特性,如果在低版本上运行可能会有问题。这个注解不会影响实际运行,但是能够在开发阶段提供有用的警告。
What is the use of @RequiresApi(Build.VERSION_CODES.M) before a method?
产生原因以及解决原因部分,部分内容参考chatgpt。
原创不易
转载请标明出处
如果对你有所帮助 别忘啦点赞支持哈