引入三方包导致 Theme 失效

本文记录了一次因引入第三方包导致的Android应用主题失效问题。详细分析了问题原因,即第三方包依赖中的同名Style在values-21文件夹下覆盖了应用的默认主题。文章提供了解决方案,包括确保主题名称的唯一性和完善主题定义。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

引入一个三方包之后导致 App 主题失效,定位了一个下午,做个记录。

AndroidManifest.xml 文件中 application 节点配置如下:

<application
    android:allowBackup="false"
    android:icon="@mipmap/app_icon"
    android:label="@string/app_name"
    android:theme="@style/AppTheme"
    tools:replace="android:allowBackup">

刚开始觉得应该是 App 的 theme 被覆盖掉了,然后添加了一个 replace

tools:replace="android:allowBackup, android:theme"

结果主题依然失效,然后把三方包中在 AndroidManifest 中注册的 Activity 挪到 App 的 Manifest 中,还是不行。

最后跳转 @style/AppTheme 时发现三方包的依赖包中也定义了一个同名的 Style,而且还是在 values-21 文件下,而 App 并没有定义 values-21 下的 Style,所以 APP 的主题就被三方包的 Style 给覆盖掉了,而 android:replace='android:theme 只有在属性冲突的时候起作用,我的 App 并没有提供 values-21 的 Style,因此没有冲突,无法 replace,于是悲剧了。

解决方案

  1. App 的主题名字最好具有唯一性, 不要叫 AppTheme,容易同名。
  2. App 的主题要定义完整,比如 values / values-21
### 配置和调用第三方API 在Spring Boot中配置并调用第三方API主要依赖于HTTP客户端工具,如`RestTemplate`或更现代的选择`WebClient`。为了简化网络操作,并提供更好的异步支持,推荐使用`WebClient`。 #### 使用 WebClient 调用第三方 API 定义一个简单的REST控制器来展示如何创建对外部资源的GET请求: ```java @RestController @RequestMapping("/api") public class ApiController { private final WebClient webClient; public ApiController(WebClient.Builder webClientBuilder) { this.webClient = webClientBuilder.baseUrl("http://third-party-api-url").build(); } @GetMapping("/fetchData") public Mono<String> fetchData() { return webClient.get() .uri("/endpoint") // 替换为实际端点路径 .retrieve() .bodyToMono(String.class); } } ``` 上述代码展示了如何利用构造函数注入的方式初始化带有基础URL的`WebClient`实例[^1]。 对于POST请求或其他类型的HTTP方法,可以通过调整`.get()`部分来适应需求,比如改为`.post().bodyValue(payload)`用于发送数据体。 #### 实现重试逻辑 为了让应用更加健壮,在遇到临时错误时自动尝试重新执行失败的操作是非常有用的。这可以通过集成Spring Retry模块轻松完成。只需添加相应的依赖项到项目的构建文件中,并按照如下方式设置重试行为: ```java @SpringBootApplication @EnableRetry public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } @Component class ApiCallerService { @Autowired private WebClient webClient; @Retryable(value = { RuntimeException.class }, maxAttempts = 3, backoff = @Backoff(delay = 100)) public String callExternalApi() { return webClient.get() .uri("/endpoint") .retrieve() .bodyToMono(String.class) .block(); // 注意这里的阻塞调用仅适用于演示目的;生产环境中应考虑非阻塞处理。 } } ``` 此示例中的`@Retryable`注解指定了当发生指定异常(`RuntimeException`)时最多允许三次重试尝试,每次等待100毫秒再进行下一次尝试[^2]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值