// 异常信息格式化 List<String> stackTraceList = LogUtil.formatStackTraceElement(stackTrace, exceptionType, exceptionCauseMsg); // 获取线程变量 List<String> threadLocalLogs = LogUtil.getThreadLocalLogs(); threadLocalLogs.addAll(stackTraceList); testResultBean.setLog(threadLocalLogs);中 threadLocalLogs.addAll(stackTraceList);报异常UnsupportedOperationException ,为什么

时间: 2024-04-19 14:24:41 浏览: 10
根据你提供的代码片段,当执行 `threadLocalLogs.addAll(stackTraceList)` 时抛出 `UnsupportedOperationException` 异常的原因可能是 `threadLocalLogs` 对象是一个不可修改的列表。 `addAll` 方法用于将另一个集合中的元素添加到目标集合中。然而,如果目标集合是只读的或不可修改的,则无法执行添加操作,会抛出 `UnsupportedOperationException` 异常。 要解决这个问题,你可以考虑使用一个可变的列表来存储日志信息,而不是使用不可修改的列表。你可以尝试使用 `ArrayList` 或 `LinkedList` 等可变列表的实现类,确保 `threadLocalLogs` 对象是可修改的。 另外,如果 `LogUtil.getThreadLocalLogs()` 方法返回的是一个不可修改的列表,你可以考虑将其转换为可变列表。例如,可以使用 `new ArrayList<>(LogUtil.getThreadLocalLogs())` 创建一个新的可变列表,并将其赋值给 `threadLocalLogs` 变量。 请注意,具体的解决方案取决于 `LogUtil` 类的实现和 `threadLocalLogs` 对象的类型。确保使用支持修改操作的可变列表来解决此问题。
相关问题

解释一下这段代码 private ImmutableList<LauncherApp> mergeWithDefaultApps( int maxLimit, ImmutableList<LauncherApp> recentApps) { int numToAdd = maxLimit - recentApps.size(); LogUtil.logD(TAG, "mergeWithDefaultApps numToAdd = " + numToAdd); if (numToAdd <= 0) { LogUtil.logDOrNotUser(TAG, "No need to merge with defaultApps"); return recentApps; } List<DefaultLauncherApp> defaultApps = loadDefaultApps(); LogUtil.logDOrNotUser(TAG, "Have to merge with " + defaultApps.size() + " default apps"); // verify that our defaults are not adding duplicates boolean enableRemovalOfDefaultRecents = enableRemovalOfDefaultRecentsProvider.get(); List<LauncherApp> matchedDefaultsList = new ArrayList<>(); for (LauncherApp app : recentApps) { Predicate<DefaultLauncherApp> matchesRecentApp = defaultApp -> matches(defaultApp, app); if (enableRemovalOfDefaultRecents) { Iterables.addAll(matchedDefaultsList, Iterables.filter(defaultApps, matchesRecentApp)); } Iterables.removeIf(defaultApps, matchesRecentApp); } if (enableRemovalOfDefaultRecents && !matchedDefaultsList.isEmpty()) { // If the user has used an app which we are populating as a default, then we can stop // promoting it in the future. hiddenDefaultRecentsHelper.hideDefaultRecentApp(matchedDefaultsList); } List<LauncherApp> mergedRecentApps = new ArrayList<>(recentApps); numToAdd = min(numToAdd, defaultApps.size()); LogUtil.logD(TAG, "numToAdd = " + numToAdd); if (numToAdd > 0) { mergedRecentApps.addAll(defaultApps.subList(0, numToAdd)); } // Try to find duplicated app and log if there is any. See b/217928263 if (LogUtil.isDorNotUser(TAG)) { Map<String, LauncherApp> appsMap = new HashMap<>(); for (LauncherApp app : mergedRecentApps) { String label = app.getLabel().toString(); LauncherApp duplicatedApp = appsMap.get(label); if (duplicatedApp != null) { LogUtil.logDOrNotUser( TAG, "Found duplicated Launcher App label:" + label + ", \nduplicated app:" + duplicatedApp + " \nand " + app); } appsMap.put(label, app); } } return ImmutableList.copyOf(mergedRecentApps); }

这段代码实现了一个方法,用于将最近使用的应用列表 recentApps 与默认应用列表 defaultApps 合并,并返回合并后的应用列表。其中,maxLimit 是最大应用数,numToAdd 是需要添加到最近使用的应用列表中的应用数量。在方法中,首先检查是否需要与默认应用列表合并,如果不需要,则返回原始的最近使用的应用列表。接下来,该方法会检查默认应用列表中的应用是否与最近使用的应用列表中的应用重复,如果重复,则从默认应用列表中删除该应用。最后,该方法将合并后的应用列表返回,如果有重复的应用,则会打印日志。

解释一下 private List<DefaultLauncherApp> loadDefaultApps() { List<DefaultLauncherApp> defaultApps = new ArrayList<>(); for (ComponentName defaultComponent : getDefaultRecents()) { ActivityDisplayInfo info = applicationInfoRepo.getActivityDisplayInfo( defaultComponent.getPackageName(), defaultComponent.getClassName()); if (info != null) { DefaultLauncherApp launcherApp = DefaultLauncherApp.from( info.getInfo(), info.getLabel(), launcherIconProvider.getLauncherIconSupplier(info, "defaultApp")); defaultApps.add(launcherApp); continue; } LogUtil.logW( TAG, "Unable to get ActivityDisplayInfo for " + defaultComponent.toShortString() + " attempting to fetch from ResolveInfo"); List<ResolveInfo> resolveInfos = applicationInfoRepo.getResolveInfo(defaultComponent.getPackageName()); if (resolveInfos.isEmpty()) { LogUtil.logW( TAG, "Unable to get ResolveInfo for " + defaultComponent.toShortString() + ", not able to add to default recents"); continue; } ResolveInfo resolveInfo = resolveInfos.get(0); ActivityInfo activityInfo = resolveInfo.activityInfo; DefaultLauncherApp app = DefaultLauncherApp.from( activityInfo, activityInfo.loadLabel(packageManager).toString(), launcherIconProvider.getLauncherIconSupplier(resolveInfo, packageManager)); defaultApps.add(app); // apply the first ResolveInfo to avoid duplicated apps. See b/223960101 if (resolveInfos.size() > 1) { LogUtil.logW( TAG, "Get multiple ResolveInfos, apply the first ResolveInfo for " + defaultComponent.toShortString() + ", to avoid duplication:" + activityInfo); } } if (enableRemovalOfDefaultRecentsProvider.get()) { // Filter based on hidden recent apps. defaultApps.removeIf(defaultApp -> shouldHideDefaultRecent(defaultApp.getActivity())); } return new ArrayList<>(); // return defaultApps; }

这是一个方法,其返回类型为私有的 List<DefaultLauncherApp>。该方法用于加载默认应用程序,并将其添加到一个名为 defaultApps 的 ArrayList 中。该方法首先获取默认最近使用过的应用程序的列表,并通过调用 applicationInfoRepo 的 getActivityDisplayInfo 方法获取每个默认应用程序的 ActivityDisplayInfo。如果能够成功获取 ActivityDisplayInfo,则将其转换为 DefaultLauncherApp 并添加到 defaultApps 中。如果不能成功获取 ActivityDisplayInfo,则通过调用 applicationInfoRepo 的 getResolveInfo 方法获取 ResolveInfo 列表,并使用第一个 ResolveInfo 创建 DefaultLauncherApp 并将其添加到 defaultApps 中。如果在获取 ResolveInfo 时发现列表为空,则将跳过该默认应用程序。如果 enableRemovalOfDefaultRecentsProvider 为 true,则将从 defaultApps 中删除应该隐藏的默认最近使用过的应用程序。最后,该方法将返回一个新的 ArrayList,其中包含 defaultApps 中的所有元素。

相关推荐

请解决implementation 'com.github.AnJoiner:FFmpegCommand:1.2.2-lite' fun getFFmpegCmd(inputFilePath: String, outputFilePath: String, watermarkFilePath: String): Array<String?>{ var height = videoHeight - DisplayHelper.dip2px(this, 50f) var width = videoWidth - DisplayHelper.dip2px(this, 100f) var strCommand = "ffmpeg -y -i ${inputFilePath} -i ${watermarkFilePath} -filter_complex [0:v]scale=iw:ih[outv0];[1:0]scale=0.0:0.0[outv1];[outv0][outv1]overlay=${width}:${height} -preset superfast ${outputFilePath}" val commands: Array<String?> = strCommand.split(" ".toRegex()).toTypedArray() return commands } fun addBitmapToVideo(inputFilePath: String, outputFilePath: String, watermarkFilePath: String) { LogUtil.d("inputFilePath=${inputFilePath},\noutputFilePath=${outputFilePath}") val addWaterMark = getFFmpegCmd(inputFilePath, watermarkFilePath, outputFilePath) try { CoroutineScope(Dispatchers.IO).launch { FFmpegCommand.runCmd(addWaterMark, object : IFFmpegCallBack { override fun onCancel() { } override fun onComplete() { finishVideo(VIDEO_COMPLETE) } override fun onError(errorCode: Int, errorMsg: String?) { LogUtil.w("水印视频错误_onError=${errorCode},${errorMsg}") finishVideo(VIDEO_ERROR) } override fun onProgress(progress: Int, pts: Long) { finishVideo(VIDEO_PROGRESS, progress) } override fun onStart() { } }) } } catch (e: Throwable) { // FFmpeg 不支持当前设备 LogUtil.w("Exception-e=${e.message}") } } backtrace: #00 pc 0x00000000000dba18 /apex/com.android.runtime/lib64/bionic/libc.so (strspn+12) #01 pc 0x0000000000339dec /data/app/~~EKJofAZ4BmKzTXggwqbGhw==/com.zsyj.facefancy-LE00NsHFRSow2FsnifHViQ==/lib/arm64/libffmpeg-org.so (avfilter_graph_parse2+80)

try { if (StringUtils.isBlank(AccessTokenInfoRequestDTO.getAccessToken())) { throw new BusinessException(ResponseCodeEnum.ACCESSTOKEN_ILLEGAL.getCode(), ResponseCodeEnum.ACCESSTOKEN_ILLEGAL.getMessage()); } else { TokenInfoDTO tokenInfoDTO = this.getTokenInfo(AccessTokenInfoRequestDTO.getAccessToken()); String accountId = tokenInfoDTO.getUserId(); String deviceToken = tokenInfoDTO.getDeviceToken(); String accToken = RedisCacheUtil.getStringForPrefix(accountId, new RedisTokenKeyEnum[]{RedisTokenKeyEnum.APP_USER_ACCOUNT}); if (StringUtils.isEmpty(accToken)) { throw new BusinessException(ResponseCodeEnum.ACCESS_TOKEN_LOSE.getCode(), ResponseCodeEnum.ACCESS_TOKEN_LOSE.getMessage()); } else if (!AccessTokenInfoRequestDTO.getAccessToken().equals(accToken)) { throw new BusinessException(ResponseCodeEnum.ACCESS_TOKEN_COVER.getCode(), ResponseCodeEnum.ACCESS_TOKEN_COVER.getMessage()); } else if (!ContextUtils.getAppRequestHeaderDTO().getDeviceToken().equals(deviceToken)) { throw new BusinessException(ResponseCodeEnum.ACCESS_TOKEN_COVER.getCode(), ResponseCodeEnum.ACCESS_TOKEN_COVER.getMessage()); } } } catch (BusinessException businessException) { LogUtil.boErrorLog("校验用户token失败:" + businessException.getMessage()); verifyAccessTokenResponseDTO = VerifyAccessTokenResponseDTO.builder().verifyFlag(false).errorDescription(businessException.getMessage()).build(); } catch (Exception exception) { LogUtil.boErrorLog("校验用户token异常:" + exception.getMessage()); verifyAccessTokenResponseDTO = VerifyAccessTokenResponseDTO.builder().verifyFlag(false).errorDescription(ResponseCodeEnum.ACCESSTOKEN_ILLEGAL.getMessage()).build(); }是啥意思

最新推荐

recommend-type

基于关键词搜索结果的微博爬虫(下载即用).zip

基于关键词搜索结果的微博爬虫(下载即用).zip本项目适合计算机相关专业(如软件工程、计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载使用,当然也适合小白学习进阶。如果基础还行,可以在此代码基础上进行修改,以实现其他功能。 基于关键词搜索结果的微博爬虫(下载即用).zip本项目适合计算机相关专业(如软件工程、计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载使用,当然也适合小白学习进阶。如果基础还行,可以在此代码基础上进行修改,以实现其他功能。 基于关键词搜索结果的微博爬虫(下载即用).zip本项目适合计算机相关专业(如软件工程、计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载使用,当然也适合小白学习进阶。如果基础还行,可以在此代码基础上进行修改,以实现其他功能。 基于关键词搜索结果的微博爬虫(下载即用).zip本项目适合计算机相关专业(如软件工程、计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载使用,当然也适合小白学习进阶。如果基础还行,可以在此代码基础上进行修改
recommend-type

node-v4.4.1-headers.tar.xz

Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
recommend-type

J波模拟matlab代码.zip

1.版本:matlab2014/2019a/2021a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

【实战演练】增量式PID的simulink仿真实现

# 2.1 Simulink仿真环境简介 Simulink是MATLAB中用于建模、仿真和分析动态系统的图形化环境。它提供了一个直观的用户界面,允许用户使用块和连接线来创建系统模型。Simulink模型由以下元素组成: - **子系统:**将复杂系统分解成更小的、可管理的模块。 - **块:**代表系统中的组件,如传感器、执行器和控制器。 - **连接线:**表示信号在块之间的流动。 Simulink仿真环境提供了广泛的块库,涵盖了各种工程学科,包括控制系统、电子和机械工程。它还支持用户自定义块的创建,以满足特定仿真需求。 # 2. Simulink仿真环境的搭建和建模 ### 2.
recommend-type

训练集和测试集的准确率都99%,但是预测效果不好

即使训练集和测试集的准确率都很高,但是在实际的预测中表现不佳,可能会有以下几个原因: 1. 数据质量问题:模型训练和测试的数据可能存在问题,比如数据标签错误、数据集采样不均衡、数据集中存在异常值等问题,这些问题可能会导致模型在实际预测中表现不佳。 2. 特征工程问题:模型的特征工程可能存在问题,导致模型无法很好地捕捉数据的特征,从而影响预测效果。 3. 模型选择问题:模型的选择可能不合适,比如选择的模型太简单,无法很好地拟合数据,或者选择的模型太复杂,导致过拟合等问题。 4. 超参数调整问题:模型的超参数可能没有调整到最佳状态,需要进行调整。 针对以上可能的原因,可以采取相应的措施进
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依
recommend-type

【实战演练】MATLAB simulink船舶动力定位模拟器

# 1. MATLAB Simulink 简介** MATLAB Simulink 是 MathWorks 公司开发的一款图形化建模和仿真软件,广泛应用于工程、科学和教育领域。它提供了丰富的模块库和仿真环境,使工程师能够快速构建和仿真复杂系统。 Simulink 的核心概念是基于块状图建模,其中每个模块代表一个特定的功能或组件。用户可以通过拖放模块并连接它们来创建系统模型。Simulink 提供了广泛的模块库,涵盖了信号处理、控制系统、动力学和通信等领域。 此外,Simulink 还支持自定义模块开发,允许用户创建自己的模块来扩展其功能。这使得 Simulink 成为一个高度灵活的仿真平