在Swift中构建布尔类型

本文介绍如何在Swift中创建一个名为MyBool的自定义布尔类型,通过使用枚举、协议和扩展来实现基本的布尔操作。文章详细解释了如何定义、赋值、比较、操作符以及一元和复合赋值运算符。

Swift中的Bool类型是许多原始函数的基础。所以基于它可以展示一个有趣的如何构建基本类型的示例。这篇文章的主旨是在Swift中创建一个类似Bool类型的新类型MyBool。我们希望通过这个简单的示例,能让你更清晰的了解Swift语言的工作原理。

让我们从最基本的定义开始。我们用枚举来定义MyBool类型的模型,它有两个不同的case

enum MyBool {
    case myTrue, myFalse
}

为了使大家不会产生混淆,这篇文章中我们将MyBool的两个case命名为myTruemyFalse。我们希望MyBool的构造函数MyBool()将其自身赋值为false,所以我们提供了如下init方法:

extension MyBool {
    init() { self = .myFalse }
}

Swift中的枚举会隐式的在它们自身内申明其枚举检索器的范围,允许我们使用MyBool.myFalse这种语法调用其成员,如果根据上下文可以推断出类型的话,我们甚至可以使用.myFalse调用其成员。但是在真正使用中,我们还是希望使用原始的truefalse关键字。想要做到这一点,我们的新类型MyBool需要遵循BooleanLiteralConvertible协议,像这样:

extension MyBool : BooleanLiteralConvertible {
    static func convertFromBooleanLiteral(value: Bool) -> MyBool {
        return value ? myTrue : myFalse
    }
}

// 我们现在就可以给MyBool类型的变量赋值为true或false.
var a : MyBool = true

通过以上设置,我们有了自己的基本类型,但是目前我们用它还做不了什么。布尔值需要通过if条件语句进行测试。在Swift中,我们通过BooleanType协议来做到这一点,该协议允许任意类型用于进行逻辑判断:

extension MyBool : BooleanType {
    func getBooleanType() -> Bool {
        switch self {
        case .myTrue: return true
        case .myFalse: return false
        }
    }   
}

// 现在我们就可以将MyBool类型的变量a用于'if'和'while'语句中进行测试.
if a {}

我们更希望所有遵循了BooleanType协议的类型都要强制转换为MyBool类型,所以我们可以这样写:

extension MyBool {
    // MyBool类型构造函数的参数设定为BooleanType类型.
    init(_ v : BooleanType) {
        if v.getBooleanType() {
            self = .myTrue
        } else {
            self = .myFalse
        }
    }
}

// 现在我们就可以这样进行转换了.
var basicBool : Bool = true
a = MyBool(basicBool)

注意构造函数里的_,它可以使我们在使用构造函数时省略参数命名。可以使用MyBool(x)这种语法,而不用使用MyBool(v: x)这种啰嗦的语法。

现在我们有了基本的功能,现在让我们来定义它的操作符,先来看看如何定义==操作符。没有关联数据的简单的枚举(像MyBool一样)是由编译器自动认为遵循Equatable协议进行编译的,所以没有必须要实现额外的代码。尽管如此,你也可以让任意类型遵循Equatable协议,并实现==操作符。比如我们的MyBool类型:

extension MyBool : Equatable {
}

func ==(lhs: MyBool, rhs: MyBool) -> Bool {
    switch (lhs, rhs) {
    case (.myTrue,.myTrue), (.myFalse,.myFalse):
        return true
    default:
        return false
    }
}

// 现在我们就可以使用==和!=进行比较了.
if a == a {}
if a != a {}

这里我们在swich语句中使用简单的匹配模式来处理。由于MyBool现在遵循了Equatable协议,所以他已经自动实现了!=操作符。再让我们加一些二进制运算符:

func &(lhs: MyBool, rhs: MyBool) -> MyBool {
    if lhs {
        return rhs
    }
    return false
}

func |(lhs: MyBool, rhs: MyBool) -> MyBool {
    if lhs {
        return true
    }
    return rhs
}

func ^(lhs: MyBool, rhs: MyBool) -> MyBool {
    return MyBool(lhs != rhs)
}

有了基本的运算符后,我们就可以实现各种有用的一元和复合赋值运算符,比如:

prefix func !(a: MyBool) -> MyBool {
    return a ^ true
}

// 复合赋值(按位)
func &=(inout lhs: MyBool, rhs: MyBool) {
    lhs = lhs & rhs
}

&=运算符将左边的运算对象作为inout对象,因为要对它进行读写操作,并且其效果对于操作者是可见的。Swift提供的值类型,使我们可以完全掌控丰富多变的各种操作,比如enumstruct

至此,简单的MyBool类型已经具备了基本的运算符操作。希望这篇文章能给你一些思路,使你能够在自己的代码中构建更高级更复杂的类型。

本文首发地址:在Swift中构建布尔类型

内容概要:本文详细记录了对一个Android ARM64静态ELF文件中字符串加密机制的逆向分析过程。该ELF文件的所有字符串均被加密,无法通过常规strings命令或IDA直接识别。作者通过分析发现,加密字符串存储在.rodata段,其解密所需信息(包括密文地址、长度和16位密钥)保存在.data.rel.ro段的40字节描述符中。核心解密函数sub_10F408采用自反的双pass流密码算法,结合固定密钥KEY_TERM(由.data段24字节数据计算得出),实现字节级线性、位置与长度相关的加密。文章还复现了完整的Python解密脚本,并揭示了该保护机制的本质为代码混淆而强加密,最终成功批量解密全部956条字符串,暴露程序实行为,如shell命令模板、设备标识篡改、网络重置等操作。此外,文中还提及未启用的自定义壳框架及其反dump设计。; 适合人群:具备逆向工程基础的安全研究人员、二进制分析人员及对ELF保护技术感兴趣的开发者。; 使用场景及目标:①学习ELF二进制中字符串加密的典型实现方式与逆向突破口;②掌握从结构识别、函数追踪到算法还原的完整逆向流程;③理解“绑定二进制”的完整性校验设计及其局限性;④实践编写IDAPython脚本自动化提取与解密敏感数据。; 阅读建议:此资源以实战案例驱动,不仅展示技术细节,更强调逆向思维与验证方法,建议读者结合IDA调试环境,逐步跟随文中步骤进行动态分析与算法验证,深入理解每一步的推理依据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值