苹果仍在研发更大尺寸的 iMac | Swift 周报 issue 60

在这里插入图片描述
在这里插入图片描述

文章目录

    • 前言
    • 新闻和社区
      • 消息称苹果仍在研发更大尺寸的 iMac 屏幕超过 30 英寸
      • 最新!苹果大动作
      • Apple Entrepreneur Camp 现已开放申请
    • 提案
      • 通过的提案
    • Swift论坛
    • 推荐博文
    • 话题讨论
    • 关于我们

前言

本期是 Swift 编辑组自主整理周报的第六十期,每个模块已初步成型。各位读者如果有好的提议,欢迎在文末留言。

Swift 周报在 GitHub 开源,欢迎提交 issue,投稿或推荐内容。目前计划每两周周一发布,欢迎志同道合的朋友一起加入周报整理。

野心太大,才华甚少。于是,回忆间遗憾,梦境中恐惧,时光里迷惘。Swift社区于流年里筑基,岁月间化形,恍惚中蜕变。所以,千日苦修,终成不朽!

周报精选

新闻和社区:消息称苹果仍在研发更大尺寸的 iMac 屏幕超过 30 英寸

提案:允许推断 TaskGroup 的 ChildTaskResult 类型提案通过审查

Swift 论坛:讨论真实应用中的 Swift 并发

推荐博文:在 SwiftUI 中追踪几何变化

话题讨论:

你希望 Apple 更加关注 AI 开发的哪个领域?

在这里插入图片描述

新闻和社区

消息称苹果仍在研发更大尺寸的 iMac 屏幕超过 30 英寸

2024 年 8 月 15 日

据外媒报道,在转向自研的M系列芯片之后,苹果公司 2021 年 4 月份推出的搭载 M1 芯片和 2023 年 10 月份推出的搭载 M3 芯片的 iMac,都是 24 英寸的屏幕,而随着 iMac Pro 和搭载英特尔芯片的 2020 年款 iMac 的下架,iMac 也就有一段没有了 27 英寸版可买,只有 24 英寸屏幕可选。

虽然苹果目前在售的 iMac 只有 24 英寸屏幕,但从去年开始,多次有外媒在报道中称苹果在研发更大尺寸的 iMac,在去年年中,就曾有消息称一款更大尺寸的 iMac,已在研发的早期阶段。不过到目前为止,尚未有更大屏幕的 iMac 推出,去年年底推出的仍是 24 英寸屏幕。

但长期关注苹果的一名资深记者透露,苹果公司仍在探索屏幕尺寸更大的 iMac。

不过,这名长期关注苹果的资深记者,目前还不确定更大尺寸的 iMac 是否会搭载苹果自研的 M4 芯片,也就是 5 月份推出的新一代 iPad Pro 率先搭载的那一款芯片。

此外,基于不同的芯片,外媒目前在更大尺寸的 iMac 的推出时间上也还有不同的看法,搭载 M4 芯片,可能就会同 MacBook Air、Mac Pro、Mac Studio 一样,在明年推出,但苹果也有可能等待 M5 芯片,推出时间可能就是在 2026 年或之后。

值得注意的是,在去年 10 月份,知名苹果产品分析师郭明錤,曾预计苹果在 2025 年将推出 32 英寸屏幕的 iMac,搭载 mini-LED 显示屏。

至于苹果是否会推出及何时推出屏幕超过 30 英寸的 iMac,要在他们正式发布之后才会揭晓,保密传统浓厚的他们,在发布之前不会公布相关的消息。(来源:TechWeb)

最新!苹果大动作

2024 年 8 月 14 日

面对欧盟等地监管方多年的压力,苹果公司终于低头。

美东时间 8 月 14 日周三,苹果宣布,从新版操作系统 iOS 18.1 开始,开发者将可使用 iPhone 内的安全元件(SE),不通过苹果旗下支付和钱包 Apple Pay 和 Apple Wallet,在开发者自行开发的 iPhone 应用程序 App 中,提供 NFC 无接触数据交换功能。

要使用这些 App 内的新功能,用户可以直接打开 App,也可以在 iOS 设置中将该 App 设置为默认支持,然后双击 iPhone 侧边按钮,即可发起交易。

苹果称,通过新的 NFC 和 SE API,开发者将能提供 App 内的无接触数据交换,可用于闭环公交、企业工牌、学生证、家门钥匙、酒店钥匙、商家积分和回馈卡,甚至活动门票等,未来还将支持身份证件。这些 API 将首先通过即将发布的 iOS 18.1 开发者资源向澳大利亚、巴西、加拿大、日本、新西兰、英国和美国的开发者提供,未来将落地更多地区。

同时苹果指出,若要在 iPhone App 中纳入上述新的无接触数据交换功能,开发者需要同苹果签订一份商业协议,申请并得到NFC和SE授权,且支付相关费用。这将确保开发者符合特定行业及监管的要求,并遵守苹果的安全和隐私标准。

上述苹果公告意味着,苹果将开始允许第三方使用 iPhone 的支付芯片来处理交易,等于允许银行和其他服务方与 Apple Pay 平台竞争。有消息称,到目前为止,只有 Apple Pay 和 Apple Wallet 可以使用 iPhone NFC 芯片的许多功能,这种“独家”优势将随着 iOS 18.1 上线而改变。

值得一提的是,今年苹果在欧盟反垄断压力下作出了一系列让步。

今年 1 月苹果宣布,对其在欧盟的 iOS、Safari 和 App 应用商店产品进行一系列历史性的大幅改革。改革将首次允许客户从苹果应用商店 App Store 以外下载软件。人们还将能够使用其他的支付系统,并且更容易地选择新的默认网络浏览器。

另据新华社报道,欧盟委员会 7 月 11 日宣布已同美国苹果公司达成和解,苹果承诺向竞争对手免费开放基于近场通信(NFC)技术的移动支付功能。相关承诺将具法律约束力,为期 10 年,适用于整个欧洲经济区。

2022 年,欧盟委员会指控苹果公司限制第三方移动支付应用开发者使用 NFC,这使苹果支付在和其他同类产品竞争中获得不公平的优势。

据欧盟委员会介绍,此前苹果提出初步承诺,向第三方移动支付应用开发者免费开放在苹果设备上的 NFC 访问权限,无需通过苹果支付或苹果钱包等。此后,欧盟委员会对苹果承诺的措施进行了市场测试,苹果也根据测试和反馈结果修改了其承诺。

欧盟委员会认可了这些承诺并表示,苹果的最终承诺将有助于消除该委员会对相关领域市场竞争的担忧。

美国媒体援引苹果公司一份声明说,该公司将为欧洲经济区的开发者在他们的相关应用程序中提供多种使用场景下启用 NFC 非接触式支付和交易的选项。(来源:每日经济新闻)

Apple Entrepreneur Camp 现已开放申请

2024 年 8 月 13 日

Apple Entrepreneur Camp 旨在为少数群体创业者和开发者提供支持,并鼓励这些企业家在技术领域不断探索并取得持续发展。课程期间会提供一对一编程指导以及与 Apple 工程师和专家沟通的宝贵机会,参与者也将成为持续扩大的全球 Apple Entrepreneur Camp 营友网络中的一员。

申请通道现已面向女性*、黑人、西班牙裔/拉丁裔和原住民创业者及开发者开放。今年,我们很高兴能再次在库比提诺的 Apple 园区举办现场活动。对于无法亲赴现场参加的人员,我们仍将提供完整的在线课程。欢迎经营 App 驱动型企业的成熟企业家进一步了解资格要求并提交申请。

申请截止日期为太平洋时间 2024 年 9 月 3 日。

提案

通过的提案

SE-0440 DebugDescription 宏 提案通过审查。该提案已在 第五十七期周报 正在审查的提案模块做了详细介绍。

SE-0441 正式化“语言模式”术语 提案通过审查。该提案已在 第五十八期周报 正在审查的提案模块做了详细介绍。

SE-0442 允许推断 TaskGroup 的 ChildTaskResult 类型 提案通过审查。该提案已在 第五十九期周报 正在审查的提案模块做了详细介绍。

Swift论坛

  1. 提议并发安全通知

内容大概

该提案旨在将 Swift 并发引入到 NotificationCenter 中,以提高代码的安全性和健壮性。目前,NotificationCenter API 通过发布和观察通知的模式,使代码解耦。这种模式在 macOS、iOS 以及其他基于 Darwin 的系统中的框架中得到了广泛集成。通知的发布者通过 Notification.Name 标识发送通知,并可以选择性地包括 object 和 userInfo 作为负载。观察者则通过注册代码块或闭包来接收通知,并可以选择指定 OperationQueue 来执行这些观察者的代码。

然而,目前的 NotificationCenter 存在一些问题。首先,通知的并发性依赖于隐式约定,观察者的代码块通常会在与发布者相同的线程上运行。为了确保并发性,客户端通常需要查阅文档或使用并发机制,这可能会导致问题。此外,现有的通知类型和负载类型并不够强,使用字符串作为标识符容易导致拼写错误,且客户端在处理通知负载时,可能需要频繁地进行类型转换。

为了解决这些问题,提案提出了一个新协议 NotificationCenter.Message,该协议允许创建可以通过 NotificationCenter 发布和观察的类型,并提供对 Swift 并发的支持,同时保留与现有 Notification 类型的互操作性。通过定义 Notification.Name,NotificationCenter.Message 可以与现有的 Notification 类型兼容。默认情况下,符合 NotificationCenter.Message 的类型的观察者将在 MainActor 上运行,并且可以指定其他的隔离上下文。

提案还介绍了如何在 NotificationCenter.Message 与现有的 Notification 类型之间进行转换,例如通过定义 makeMessage(_:) 方法将通知转换为 NotificationCenter.Message,或通过 makeNotification(_:) 方法将 NotificationCenter.Message 转换为现有的 Notification 类型,以支持现有的 Objective-C 代码中的观察者。

提案的一个示例展示了如何将现有的 NSWorkspace.willLaunchApplicationNotification 通知适配为使用 NotificationCenter.Message,并展示了如何在客户端代码中观察和发布这样的通知。

该提案不仅增强了类型安全性和并发支持,还通过平滑的过渡路径确保了与现有代码库的兼容性。

  1. 讨论真实应用中的 Swift 并发

内容大概

在实际应用中使用 Swift 并发可能会带来一些复杂性和挑战。作者分享了一个自定义 NSTableColumn 的代码示例,该示例使用图片而不是字符串作为列头。在实现过程中,作者遇到了与 Swift 并发相关的问题,特别是在 Xcode 16 beta 5 中,某些以前可行的方法突然失效了。

代码示例如下:

final class LockTableColumn: NSTableColumn {lazy private var _headerCell: NSTableHeaderCell? = niloverride var headerCell: NSTableHeaderCell {get {if _headerCell != nil { return _headerCell }_headerCell = super.headerCell // 保留父类提供的默认样式if let image = NSImage(systemSymbolName: "lock.fill", accessibilityDescription: nil) {image.size = CGSize(width: 14, height: 14)Task { @MainActor [_headerCell] in_headerCell!.image = image}}return _headerCell}set {// 空操作}}
}

作者提到,NSTableColumn 并没有被标记为可发送(sendable),而 NSCell 则被绑定到 MainActor 上,这使得这两者的结合使用变得困难。特别是,当尝试在代码中使用 Task { @MainActor in } 来设置图片属性时,编译器会抛出错误,提示任务或 actor 隔离值无法发送。为了解决这个问题,作者必须使用捕获列表 [ _headerCell ],但这一点并不直观,特别是对于初学者来说。

作者还指出,Swift 并发的严格性导致了一些简单任务的实现变得异常复杂,并质疑当前 Swift 并发的成熟度和苹果框架的准备情况。不断变化的开发环境(如 beta 版本之间的差异)进一步增加了学习和采用 Swift 并发的难度。

此外,作者讨论了在大型、旧项目中使用 Swift 并发的挑战,特别是在尝试迁移到 Swift 6 时遇到的困难。虽然迁移可能是一个长期的过程,但作者认为,尽早采用新特性比等待其完全成熟更为可取。

总之,尽管 Swift 并发在理论上提供了更好的安全性,但在实践中,它可能会增加开发的复杂性,特别是在现有代码库中。

  1. 提议未实现函数的占位符

内容大概

讨论了对未实现函数的占位符进行改进的提案。提案的核心思想是引入一种新的语法,用于明确标记未实现的函数或方法。这种语法将帮助开发者在编写和维护代码时更清楚地识别出哪些部分尚未完成,从而减少遗漏和错误。

提案中提出了以下几个关键点:

  1. 建议添加一个新的关键字或标记,来表示一个函数或方法尚未实现。这种标记可以使代码在编译时产生警告或错误,提醒开发者注意未完成的部分。

  2. 通过这种标记,开发者可以在代码中添加详细的注释或文档,说明该函数将来会实现的功能。这有助于团队成员之间的沟通,并且在代码审查过程中提供更多的信息。

  3. 提案中提供了几个具体的语法示例,展示如何使用这种新语法标记和处理未实现的功能。这些示例展示了不同情况下的用法,并说明了这种方法如何提高代码的可读性和可维护性。

总的来说,这项提案旨在提高代码的清晰度和可靠性,帮助开发者更有效地管理未实现的功能。

  1. 讨论测试基于闭包的异步 API

内容大概

在XCTest中,当设置一个非零超时时间时,fulfillment(of:timeout:) API 会旋转运行循环并等待最长指定时间,直到 XCTestExpectation 被满足。相对而言,Swift Testing 中的 confirmation() API 不会等待,它要求 Confirmation 在闭包返回之前得到确认。

在实际应用中,start() 函数创建了一个无结构的Task,但没有等待其值,这意味着当 start() 返回时,任务中的异步操作可能尚未完成。为了解决这个问题,可以修改代码,让 start() 函数返回一个 Task,并在 confirmation() 闭包中等待该任务完成。具体做法是:

@MainActor
@discardableResult
func start() -> Task<...> {Task {// 异步操作}
}

然后在 confirmation 闭包中等待任务完成:

await confirmation { confirmed inenv.analytics.trackEventMock.whenCalled { _ inconfirmed()}let startingTask = await sut.start()await startingTask.value
}

虽然这种方法在理论上可行,但实际应用中受到限制,特别是当需要创建与并发模型无关的 ViewModel 时。在这种情况下,ViewModel 通常具有一个同步接口,并且只从视图层访问。视图通过该接口向 ViewModel 发送信号,ViewModel 启动一个 Task,或者在旧代码中使用 Combine 或传统的闭包 API。当异步操作完成时,ViewModel 会更新状态并通过 @Published 属性或 Observation 框架将其传递到视图层。

由于 Swift Testing 的确认机制无法正常工作,这使得采用该框架变得困难。工程师们可能只能在新项目中使用该框架,而不能在现有项目中轻松集成。

  1. 讨论ShapedArray 中 4D 及更高维度的下标

内容大概

讨论中,有关 ShapedArray 的子脚本功能的扩展请求涉及了几个关键方面:

  1. 当前,ShapedArray 可以处理一维、二维和三维数组的索引和子脚本操作。这意味着对于这些维度的数据,用户可以通过索引轻松地访问和修改元素。然而,对于四维及更高维度的数组,现有的 ShapedArray 实现尚不支持直接的子脚本操作。

  2. 用户希望能够对更高维度的数组进行类似的一维、二维、三维数组那样的子脚本操作。这种需求通常来源于需要处理复杂的数据结构,如多维矩阵或张量,这在科学计算、机器学习和图像处理等领域非常常见。

  3. 讨论中建议通过扩展 ShapedArray 的子脚本功能,允许对四维及更高维度的数组进行直观的访问。例如,能够通过多个索引进行访问,如 array[x][y][z][w],其中每个索引对应数组的不同维度。这将使得操作这些复杂数据结构变得更加简洁和高效。

  4. 扩展子脚本功能以支持更高维度数组面临一些技术挑战,包括:

    • API设计: 需要设计一个易于理解和使用的API,同时支持灵活的维度访问。
    • 性能考虑: 高维数组的操作可能会涉及大量数据,如何优化性能以确保高效的访问和操作是一个重要问题。
    • 兼容性: 确保新的功能不会破坏现有的ShapedArray实现,并且能够与现有代码库兼容。

综上所述,扩展 ShapedArray 以支持四维及更高维度的子脚本操作被认为是一个有价值的改进,能够显著提升处理复杂数据结构的灵活性和效率。然而,实施这一改进需要解决若干技术挑战,并考虑如何设计一个用户友好的 API。

推荐博文

深入探究 Swift 中 String 的内存布局及底层实现

摘要: 这篇博客深入探讨了 Swift 中的 String 类型的内存布局和底层实现。文章通过查看内存、汇编代码及 Swift 源码,详细分析了 String 的内部结构。主要内容包括:

空字符串:String 内部有一个 _StringGuts 结构体,包含 _StringObject 成员,_StringObject 持有一个 Builtin.BridgeObject 类型的 _object 和一个 UInt64 类型的 _countAndFlagsBits

小字符串:当字符串长度不超过 15 时,字符串内容直接存储在变量地址中,使用 16 个字节存储,前 15 个字节存储字符,最后 1 个字节存储长度和标志位。

大字符串:当字符串长度超过 15 时,字符串变量的内存布局发生变化,地址中的部分字节存储字符串长度,另一部分存储字符串内容的地址。_object 字段通过位操作和偏移量管理字符串的实际存储地址。

平台差异:文章也讨论了 64 位、32 位和 16 位平台上的不同内存布局,并结合 Mach-O 文件分析了字符串在内存中的位置。

最终,文章总结了 Swift 字符串的内存布局:在 64 位平台上, String 占用 16 个字节,长度小于等于 15 的字符串直接存储在这 16 字节中。

Swift 开发新高度:自己动手实现 Optional 类型

摘要: 这篇文章讲述了如何自己实现 Swift 中的 Optional 类型。作者介绍了 Swift 内置的 Optional 是一个枚举类型,具有 some 和 none 两个 case,并使用泛型来处理不同类型的数据。作者随后展示了如何定义一个自定义的 Optional 类型 CustomOptional,并为其添加了方法来访问、解包值,以及通过 map 和 flatMap 方法实现可选链。通过这些步骤,读者可以更深入地理解 Swift Optional 的底层实现和代数数据类型的强大功能。

在 SwiftUI 中追踪几何变化

摘要: 这篇博客介绍了如何在 SwiftUI 中使用新的 onGeometryChange 修饰符来追踪视图的几何变化。作者详细说明了 onGeometryChange 的三个参数:可观察的结果类型、用于几何转换的闭包,以及处理转换结果的闭包。作者提供了多个示例,展示了如何在 ScrollView 中追踪视图的尺寸和位置变化,并强调了该修饰符对性能优化的重要性。

话题讨论

你希望 Apple 更加关注 AI 开发的哪个领域?

  1. 增强机器学习模型和工具
  2. 更好地将 AI 与 Swift 和 Xcode 集成
  3. 更多 AI 开发资源和教程
  4. 改进 AI 的隐私和安全功能
  5. 其他(用户输入)

关于我们

Swift社区是由 Swift 爱好者共同维护的公益组织,我们在国内以微信公众号的运营为主,我们会分享以 Swift实战SwiftUlSwift基础为核心的技术内容,也整理收集优秀的学习资料。

特别感谢 Swift社区 编辑部的每一位编辑,感谢大家的辛苦付出,为 Swift社区 提供优质内容,为 Swift 语言的发展贡献自己的力量。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/57259.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

我谈傅里叶变换幅值谱的显示

在图像处理和分析中通常需要可视化图像傅里叶变换的幅值谱。通过幅值谱&#xff0c;可以直观地观察频率成分的分布&#xff0c;帮助理解图像的结构和特征。 很多刊物中直接显示傅里叶变换的幅值谱。 FFT fftshift(fft2(double(Img))); FFT_mag mat2gray(log(1abs(FFT)));由…

跨时钟域处理(单bit)_2024年10月21日

慢时钟域同步到快时钟域&#xff1a;打两拍 在快时钟域clk下对慢时钟域信号进行打两拍&#xff08;亚稳态概率很低&#xff09; 脉冲宽度改变&#xff0c;但不影响同步结果 快时钟域同步到慢时钟域&#xff08;两种方法&#xff09; ① 脉冲展宽同步 在快时钟域clk下对快时…

基于卷积神经网络的蔬菜识别系统,resnet50,mobilenet模型【pytorch框架+python源码】

更多目标检测和图像分类识别项目可看我主页其他文章 功能演示&#xff1a; 基于卷积神经网络的蔬菜识别系统&#xff0c;resnet50&#xff0c;mobilenet【pytorch框架&#xff0c;python&#xff0c;tkinter】_哔哩哔哩_bilibili &#xff08;一&#xff09;简介 基于卷积神…

单神经元建模:基于电导的模型[神经元结构、静息电位和等效电路]

文章目录 神经元结构、静息电位和等效电路神经元结构静息电位能斯特方程1. **描述浓度比的非线性关系**&#xff1a;2. **化学势与电势的关系**&#xff1a;3. **对称性**&#xff1a;4. **热力学与平衡**&#xff1a;总结&#xff1a; GHK方程Nernst方程和GHK方程的对比 等效电…

《仓库猎手模拟》风灵月影游戏辅助使用教程

《仓库猎手模拟》是一款休闲独立的模拟经营佳作&#xff0c;让玩家沉浸于经济管理的乐趣中&#xff0c;亲手利用工具探索仓库的每个角落&#xff0c;发掘并鉴定珍稀物品。借助修改器&#xff0c;玩家能更轻松地享受游戏过程&#xff0c;体验寻宝与经营的双重乐趣。 修改器安装&…

【C语言】文件操作(2)(文件缓冲区和随机读取函数)

文章目录 一、文件的随机读取函数1.fseek函数2.ftell函数3.rewind函数 二、文件读取结束的判断1.被错误使用的feof2.判断文件读取结束的方法3.判断文件结束的原因feofferror判断文件读取结束原因示例 三、文件缓冲区 一、文件的随机读取函数 在上一篇的文章中&#xff0c;我们讲…

Android10 recent键相关总结

目录 初始化流程 点击Recent键流程 RecentsActivity 显示流程 RecentsModel 获取数据管理类 RecentsActivity 布局 已处于Recent界面时 点击recent 空白区域 点击返回键 recent组件配置 Android10 Recent 功能由 System UI&#xff0c;Launcher共同实现。 初始化流程 …

如何克隆Git仓库的子目录:稀疏检出

一、环境 Git 2.34.1 二、前言 一般来说&#xff0c;我们在克隆git仓库的时候&#xff0c;都是一整个仓库都克隆出来的。如果假设现在有一个很大的仓库&#xff0c;仓库里有多个子项目&#xff0c;而我们只想克隆其中一个子项目的时候&#xff0c;应该怎么做呢&#xff1f; …

【Java后端】之 ThreadLocal 详解

想象一下&#xff0c;你有一个工具箱&#xff0c;里面放着各种工具。在多人共用这个工具箱的时候&#xff0c;很容易出现混乱&#xff0c;比如有人拿走了你的锤子&#xff0c;或者你找不到合适的螺丝刀。为了避免这种情况&#xff0c;最好的办法就是每个人都有自己独立的工具箱…

初识适配器模式

适配器模式 引入 生活中的例子&#xff1a;当我们使用手机充电时&#xff0c;充电器起到了转换器的作用&#xff0c;它将家用的220伏特电压转换成适合手机充电的5伏特电压。 适配器模式的三种类型 命名原则&#xff1a;适配器的命名应基于资源如何传递给适配器来进行。 类适配…

第14篇:下一代网络与新兴技术

目录 引言 14.1 下一代网络&#xff08;NGN&#xff09;的定义与特点 14.2 IPv6协议的改进与未来应用 14.3 软件定义网络&#xff08;SDN&#xff09; 14.4 网络功能虚拟化&#xff08;NFV&#xff09; 14.5 量子通信网络 14.6 软件定义广域网&#xff08;SD-WAN&#x…

xlsx xlsx-style-vite 实现前端根据element 表格导出excel且定制化样式 背景 列宽等

前言 先看下最终效果图吧&#xff0c;需要的可以参考我的实现方式 这是最终导出的表格文件 类似这种的&#xff0c;特定单元格需要额外标注&#xff0c;表头也有月份然后细分的&#xff0c;表格组件是这样的 注意 别使用xlsx-style 这个库&#xff0c;太多问题了&#xff0c;…

【C语言刷力扣】1768.交替合并字符串

题目&#xff1a; 解题思路&#xff1a; 将 word1 和 word2 元素依次添加至 ans 的后面。 时间复杂度&#xff1a; &#xff0c; n是word1的长度 m是word2的长度 空间复杂度&#xff1a; char* mergeAlternately(char* word1, char* word2) {int len1 strlen(word1);in…

【Linux】top命令查看CPU、内存使用率、解释

1. top 命令 top 是最常用的实时监控工具之一&#xff0c;可以显示 CPU 的总利用率以及各个进程的 CPU 使用情况。在Linux命令行直接输入top即可查看动态原始数据 top 在 top 命令的输出中&#xff0c;最上面的一行会显示 CPU 的使用情况&#xff1a; us&#xff08;User&a…

图片怎么转文字?11种好用的方法!

如何快速将图片的文字提取出来&#xff0c;可以大量节省手打的时间&#xff0c;无论是截图&#xff0c;或者批量提取照片文字&#xff0c;都经常需要这个操作&#xff01; 作为一名社畜&#xff0c;俺也经常用到各种图片转文字工具&#xff0c;今天通过测评12个主流的图片转文…

面对AI算力需求激增,如何守护数据中心机房安全?

随着人工智能&#xff08;AI&#xff09;技术飞速发展&#xff0c;AI算力需求呈现爆发式增长&#xff0c;导致对数据设备电力的需求指数级攀升。这给数据中心带来前所未有的挑战和机遇&#xff0c;从提供稳定的电力供应、优化高密度的部署&#xff0c;到数据安全的隐私保护&…

OpenVLA-首个开源视觉语言动作大模型

官网&#xff1a;https://openvla.github.io/ 现在大模型已经卷到了机器人领域。 在视觉语言模型&#xff08;VLM&#xff09;的基础上&#xff0c; 加入机器人的动作&#xff08;Action) 这一模态&#xff0c; 视觉语言动作大模型&#xff08;VLA&#xff09;是目前大模型应用…

2024新手攻略:项目管理工具+PMP备考经验不容错过!

&#xff08;一&#xff09;热门工具大盘点 禅道是一款专注于软件开发项目管理的工具。它涵盖了项目管理的各个环节&#xff0c;包括需求管理、任务分配、缺陷跟踪等。禅道的优势在于其对软件开发流程的深入理解和支持&#xff0c;能够帮助开发团队更好地管理项目进度和质量。…

如何应对 Android 面试官 -> ANR 如何优化?线上 ANR 如何监控?

前言 本章主要围绕 ANR 如何监控以及优化&#xff1b; 基本概念 ANR(Android Not Responding) 是指应用程序未响应&#xff0c;Android 系统对于一些事件需要在一定的时间范围内完成&#xff0c;如果超过预订时间未能得到有效响应或者响应时间过长&#xff0c;都会造成 ANR。 …

91 VRRP负载局衡+主备切块 V2

实操四 负载均衡主备 VRRP&#xff08;虚拟路由冗余协议&#xff09;是一种网络协议&#xff0c;用于提高网络的可用性和冗余性。VRRP可以将多个路由设备组成一个虚拟路由器&#xff0c;当主路由设备故障时&#xff0c;自动切换到备用路由设备&#xff0c;从而实现高可用性。 …