前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >苹果 iPhone SE 4 售价曝光 | Swift 周报 issue 54

苹果 iPhone SE 4 售价曝光 | Swift 周报 issue 54

原创
作者头像
Swift社区
修改2024-07-29 07:58:34
1720
修改2024-07-29 07:58:34
举报
文章被收录于专栏:Swift社区

前言

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

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

生活有望穿秋水的等待,也会有意想不到的惊喜。Swift社区给你勇气,向昨天说再见,给今日奖新程!👊👊👊

周报精选 新闻和社区:苹果 iPhone SE 4 售价曝光提案:不可复制的标准库原语提案正在审查Swift 论坛:讨论嵌套类型无法识别递归方法中的协议一致性 推荐博文:RxSwift 6 更新了什么 话题讨论: 《2024歌手》节目近期强势来袭,如火如荼、异常火爆,多国歌王齐聚一堂,精彩不断。都说音乐是不分国界与种族的,但歌曲却有着不同的种类,那么你心目中的天籁是怎样的类型呢? 上期话题结果

通过投票结果可以发现,更多的人购买 iPad 是为了体验与收集不同的新功能。新鲜劲过去之后也只能沦为看电视剧的工具。建议大家理性消费。

新闻和社区

苹果上架 iPhone 14/Pro 官翻机:起售价不到 5000 元

2024 年 7 月 18 日

苹果每年在推出新 iPhone 之后,都会将前一代的 Pro 系列直接下架,无法通过官网购买。

不过苹果最新在美国官网重新上架了 iPhone 14、iPhone 14 Pro 和 iPhone 14 Pro Max 三款机型,都是官方翻新机。

美国苹果线上商城苹果 iPhone 14 的起售价为 619 美元(约合 4488 元人民币),比全新价 699 美元便宜 80 美元,最高容量可以达到 256GB。

苹果 iPhone 14 Pro 的起售价为 759 美元(约合 5503 元人民币),iPhone 14 Pro Max 的起价为 849 美元(约合 6155 元人民币),有多种配置和颜色可供选择。

高容量机型的折扣幅度更大,最高有 1TB 可选。

值得注意的是,这也是目前唯一从苹果官方能够购买到 iPhone 14 Pro 的方式。

虽然是翻新产品,但是苹果都经过了严格的检测和处理,进行彻底的清洁,并升级最新系统,在外观和功能性完全与新机一致。

所有翻新设备均使用全新包装盒重新包装,并包含随附配件和连接线。

同时苹果还承诺,所有翻新 iPhone 均可享受一年保修服务以及免费的送货和退货服务。(来源:快科技)

苹果 iPhone SE 4 售价曝光

2024 年 7 月 19 日

据最新消息,苹果公司计划在明年推出新一代 iPhone SE 。这款机型将迎来重大更新,并为消费者带来更多惊喜和创新。虽然价格一直是 iPhone SE 系列的卖点之一,但根据爆料人士透露,苹果公司计划对新款 iPhone SE 的价格进行调整。

据悉,下一代 iPhone SE 的美国售价可能会比当前的 iPhone SE 3( 64GB 版本)高出约 10%,达到约 469 美元。尽管价格有所上涨,但新款 iPhone SE 的定价仍将在 500 美元以下。考虑到汇率等因素的影响,新款 iPhone SE 在其他地区的定价可能也会有所不同。

按照苹果公司的惯例,在对其进行重大重新设计时,产品价格往往会相应提升。例如全新设计的第四代 iPad Air 和第十代 iPad 等产品以及与 iPhone 8 相比价格大幅上涨的 iPhone X 都体现了这一点。

回顾一下 iPhone SE(第三代)的基本参数:搭载了 A15 芯片、4.7 英寸 LCD 屏幕以及后置单摄 1200 万像素摄像头,并且电池容量为 2018mAh。

苹果针对欧盟 20 亿美元罚单提起上诉 双方另一场“缠斗”已跨越近八年

2024 年 7 月 19

7 月 19 日讯(编辑 夏军雄)法庭文件显示,苹果公司已在欧盟普通法院提起诉讼,要求推翻欧盟委员会此前对其处以的 20 美元罚款。

今年 3 月,欧盟委员会对苹果处以 18.4 亿欧元(合 20 亿美元)的罚款,原因是该公司涉嫌滥用其在音乐流媒体应用分发市场上的主导地位。

这是欧盟首次对苹果处以反垄断罚款,也是欧盟对科技公司开出的最大罚单之一。欧盟此前曾对谷歌处以两笔巨额罚款,分别高达 43 亿美元和 24 亿美元,谷歌也已针对这两起案件提起上诉。

2019 年 3 月,瑞典音乐流媒体服务商 Spotify 针对苹果应用商店 30% 的抽成比例提起诉讼,指控苹果公司滥用平台主导地位。欧盟监管机构在2020年6月对苹果启动了反垄断调查。

逾 18 亿欧元的罚款远远超出了市场预期,苹果也在罚款落地后第一时间就表示将提起上诉。

需要说明的是,欧盟法院分为三部分,分别是(欧盟)普通法院、专门法庭和欧洲法院(最高法院)。

欧盟普通法院作出裁决可能需要耗时数年之久,若判决结果对苹果不利,该公司仍可继续上诉到欧洲法院,而这可能会将诉讼再拖几年。

欧盟和苹果还有另一场“缠斗”

就在苹果针对欧盟委员会的罚单提出上诉之际,两者另一场“缠斗”的最终结果仍然悬而未决。

2016 年 8 月,欧盟委员会裁定,苹果在爱尔兰享受的低税率等同于爱尔兰为其提供国家补贴,而这与欧盟相关规则不符,苹果需补缴高达 130 亿欧元的税款。爱尔兰政府和苹果随后对此裁定进行上诉。

2020 年 7 月,欧盟普通法院判决,欧盟委员会 2016 年的裁定未能在法律上证实苹果享受的低税率是不公平的,撤销欧盟委员会 2016 年有关裁定。

去年 7 月,欧盟委员会向欧洲法院提起上诉,请求推翻欧盟普通法院的裁决,要求苹果公司向爱尔兰补缴 130 亿欧元的税款。

去年 11 月,欧洲法院总顾问表示,欧盟普通法院在裁定苹果避税案时犯了法律错误,应重新审查此案。这意味着苹果可能需要补缴高达 130 亿欧元的税款。(来源:财联社)

提案

通过的提案

SE-0436 Objective-C 在 Swift 中的实现 提案通过审查。该提案已在 第五十三期周报 正在审查的提案模块做了详细介绍。

SE-0435 每个目标的 Swift 语言版本 提案通过审查。该提案已在 第五十三期周报 正在审查的提案模块做了详细介绍。

SE-0430 transferring 参数和结果值的隔离区域 该提案已在 五十期周报 正在审查的提案模块做了详细介绍。在第五十二期周报时被拒绝。本期重新恢复审查。本期该提案通过审查。

正在审查的提案

SE-0436 不可复制的标准库原语 提案正在审查。

相关提案:

  • SE-0377 借用和消耗参数所有权修饰符
  • SE-0390 不可复制的结构体和枚举
  • SE-0426 BitwiseCopyable
  • SE-0427 不可复制的泛型
  • SE-0429 不可复制值的部分消耗
  • SE-0432 对不可复制类型的借用和消耗模式匹配

在此提案中,我们扩展了标准库中的以下泛型类型,使其支持不可复制的类型参数:

  • enum Optional<Wrapped: ~Copyable>
  • enum Result<Success: ~Copyable, Failure: Error>
  • struct MemoryLayout<T: ~Copyable>
  • struct UnsafePointer<Pointee: ~Copyable>
  • struct UnsafeMutablePointer<Pointee: ~Copyable>
  • struct UnsafeBufferPointer<Element: ~Copyable>
  • struct UnsafeMutableBufferPointer<Element: ~Copyable>
  • class ManagedBuffer<Header, Element: ~Copyable>
  • struct ManagedBufferPointer<Header, Element: ~Copyable>

OptionalResult 变得有条件地可复制,其可复制性继承自其类型参数。上述所有其他类型仍然是无条件可复制的,与其类型参数的可复制性无关。

我们还更新了一个标准协议,以允许不可复制的符合类型:

  • protocol ExpressibleByNilLiteral: ~Copyable

Swift论坛

1) 讨论泛型实现不适用于具体类型

内容概括

用户正尝试在 Swift 中创建一个通用实现来处理更新存储的操作,但他们在具体类型方面遇到了困难。他们提供了一个使用泛型的示例,该示例具有适用于特定类型(“State”、“Add”和“Remove”)的“Updater”结构。“Updater”可以使用“Add”或“Remove”修饰符来修改“State”对象,并且此特定实现有效。

但是,在尝试创建一个更通用的函数来处理更新时,他们遇到了一个问题:该函数无法确定要使用哪种特定的“apply”方法,从而导致“Add”和“Remove”的实现之间产生混淆。

然后,用户尝试了一种替代方法,即直接将“apply”方法添加到“State”结构中,这种方法有效并且允许更方便的代码。尽管如此,在保持相同功能和便利性的同时使方法通用化还是存在问题。用户正在寻求一种解决方案,以通用方式实现这些操作,而不会失去易用性或功能性。

2) 提议SE-0437:将标准库原语推广至不可复制类型

内容概括

Swift 社区目前正在审查 SE-0437,该提案提议将标准库原语推广到不可复制类型。审查期持续到 2024 年 6 月 4 日。

该提案对 Optional、Result 和其他不安全和托管缓冲区类型进行了更改,旨在提供更清晰的信息和必要的调整,尤其是关于消费更改。该提案与早期的 Swift Evolution 提案一致,并且看起来很合理,尽管由于消费等新概念可能会出现潜在的编译器错误。

虽然这些更改的影响最初可能很小,但它们为标准库的更广泛增强铺平了道路,例如现有写时复制集合类型(如 Array、Set、Dictionary 和 String)的替代方案。这包括为客户端引入控制运行时和内存性能的选项,例如固定容量数组或堆栈分配的字典。

但是,审阅者表达了对进一步发展的渴望,特别是关于不可复制容器类型(如 Hypoarray)。了解中间步骤以及这些变化如何有助于实现增强 Swift 标准库的更广泛目标仍然是一个值得关注的问题。

总体而言,该提案似乎是朝着解决 Swift 标准库中的写时复制行为和性能控制的更广泛问题迈出的一步。

3) 提议RFC:允许工具版本 >= 6.0 中的包级依赖循环

内容概括

该提案寻求对 Swift 工具 6.0 版及更高版本依赖关系解析的更改的反馈。当前禁止包级依赖循环的规则将被取消,允许包相互依赖,只要它们的目标(模块)不形成循环。例如,包 A 可以依赖于包 B,反之亦然,只要它们的产品/目标不相互依赖。

此更改针对小众用例,例如测试框架,在这种情况下,库使用与框架本身用于测试的相同框架是合理的。

一个微妙的问题是,在包中引入新的依赖项可能会破坏源代码,如果它与另一个包形成循环,则需要主要版本升级。例如,如果包 A 依赖于包 X,则在包 X 中的模块之间添加新的依赖项可能会引入循环,从而需要主要版本更新。

对于那些对详细更改感兴趣的人,该提案包含指向 GitHub 上特定拉取请求的链接。作者认为这种变化是可管理的,不会造成交易破坏,但开发人员必须意识到在这些情况下发生源代码破坏性变化的可能性。

4) 讨论嵌套类型无法识别递归方法中的协议一致性

内容概括

用户在 Swift 中遇到了嵌套类型和递归方法中的协议一致性问题。他们的场景涉及 ElementContainer 协议,其中 Container 符合 Element 并且可以包含其他元素,包括嵌套容器。

问题描述

用户定义协议和类型:

  • 协议ElementContainer(其中包括符合 Element 的关联类型 Child)。
  • 类型ExampleElementExampleContainer

然后,他们扩展 Container 以包含 action() 方法,该方法的行为取决于 Child 是否也是 Container

预期行为

对于嵌套容器,action() 方法应根据 Child 的类型识别并递归调用适当的 action() 方法。

观察到的行为

该方法正确识别并打印第一级嵌套的消息,但无法识别更深的层次。具体来说,对于三重嵌套容器,它无法正确将第二级容器识别为容器。

解决方法

手动解决方法涉及添加具有更具体的 where 子句的其他方法重载,但这不可扩展或不优雅。

用户的期望结果

他们希望 action() 方法能够递归地了解类型一致性,而无需手动指定每个嵌套级别。

附加目标

用户还希望实现一个 flatten() 方法,该方法返回所有元素的平面数组,正确识别嵌套容器和非容器。

问题和挑战

  1. 为什么会发生这种情况: Swift 的类型系统和协议一致性检查不像这种场景所需的那样动态或递归。如果没有明确的类型约束,Swift 不会自动推断嵌套一致性。
  2. 所需方法: 一种处理任意嵌套级别的递归方法,正确识别和处理嵌套容器。

解决方案

用户寻求一种更动态的解决方案来管理递归方法中的类型感知,从而实现对嵌套容器的高效且可扩展的处理。他们需要一种方法将嵌套容器展平为单个元素数组,同时让编译器理解类型关系。

结论

用户在涉及嵌套类型的递归方法中遇到了 Swift 协议一致性检查的限制。他们希望找到一种解决方案,允许动态和递归类型处理,使 action()flatten() 等方法能够与嵌套容器无缝协作。

5) 讨论多个变量声明中的优先级

内容概括

用户正在寻求澄清 Swift 中关于多个变量声明优先级的特定行为。他们提供了代码示例,其中变量赋值的顺序似乎会导致意外的默认值。

在第一个示例中,他们观察到,当以“let y = f(x), x = 100”的顺序声明变量“y”和“x”时,“y”默认为零而不是 100,尽管“x”在语句的后面被赋值。

他们通过涉及不同类型赋值的附加代码示例(IntBoolstruct 实例)进一步说明了这种行为,当以特定顺序声明变量时,所有代码示例都表现出类似的意外默认值。

用户寻求澄清为什么会发生这种行为,并请求指导或来源以更好地理解它。

该主题继续进行讨论,并尝试解释这种行为以及在变量声明中实现所需结果的可能解决方法。

推荐博文

Swift 中的捕获列表:弱引用、强引用和无主引用之间的区别

摘要: 这篇博客深入探讨了闭包捕获列表(Capture lists)在 Swift 中的应用,特别是在解决强引用循环(retain cycles)和内存管理方面的作用。文章先介绍了闭包捕获列表的基本概念和使用方法,然后详细讨论了其中的三种引用类型:强引用(strong)、弱引用(weak)、无主引用(unowned),以及它们在不同场景下的应用和注意事项。

此外,作者还探讨了在闭包捕获过程中可能遇到的常见问题,并提供了相应的解决方案和建议。这篇博客通过丰富的例子和详细的解释,帮助读者深入理解闭包捕获列表的原理和实践应用,以及如何避免常见的内存管理问题。

RxSwift 6 更新了什么

摘要: 文章详细介绍了 RxSwift 6 带来了一系列增强和新功能,旨在简化和改进 Swift 中的响应式编程。从 Binder 迁移到 RxSwift,到使用动态成员查找自动合成 Binder,开发人员可以期待更流畅、更高效的编码体验。

重要新增功能包括用于更好地管理内存的 withUnretained 操作符,引入了不可失败流 Infallible,以及像 decode 和 distinctUntilChange(at:) 这样的新操作符。Variadic drive()emit() 操作符提供了更大的绑定灵活性,而 Single 的改进使其与 Swift 的 Result 类型更加一致。ReplayRelayDisposeBag 函数构建器以及更好的 XCFramework 支持进一步增强了 RxSwift 的可用性和性能。这些更新,加上大量操作符重命名和错误修复,使 RxSwift 6 成为 Swift 中响应式编程的重要进步。

Swift 中的任务组

摘要: 文章介绍了 Swift 中的任务组,它是一组并发运行的子任务的集合,只有当所有子任务都完成执行时才返回。文章涵盖了如何创建任务组、向其中添加子任务以及收集所有子任务的结果。任务组的关键行为,包括子任务独立并且并发运行,任务组只有在所有子任务完成执行时才返回。

作者演示了如何使用 withTaskGroup 创建任务组,并在任务组的主体内使用 addTask 方法添加子任务。文章在左后解释了如何使用循环收集所有子任务的结果,并提供了一个示例代码片段来说明整个过程。示例代码的输出确认了所有子任务都是并发运行的,并且任务组只有在所有子任务完成后才返回。

话题讨论

《2024歌手》节目近期强势来袭,如火如荼、异常火爆,多国歌王齐聚一堂,精彩不断。都说音乐是不分国界与种族的,但歌曲却有着不同的种类,那么你心目中的天籁是怎样的类型呢?

  1. 华语金曲YYDS。
  2. 英文歌曲更显优雅。
  3. 粤语经典经久不衰。
  4. 民谣淳朴宛转悠扬。

欢迎在文末留言参与讨论。

关于我们

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

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

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 新闻和社区
    • 苹果上架 iPhone 14/Pro 官翻机:起售价不到 5000 元
      • 苹果 iPhone SE 4 售价曝光
        • 苹果针对欧盟 20 亿美元罚单提起上诉 双方另一场“缠斗”已跨越近八年
        • 提案
          • 通过的提案
            • 正在审查的提案
            • Swift论坛
            • 推荐博文
            • 话题讨论
            • 关于我们
            相关产品与服务
            容器服务
            腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档