@dataclass数据类 / 内置函数的用法

"""
关于第一个Message1类定义的缺点:
① 书写麻烦
② 一旦需要再加一个值进行修改,则整个类中的所有内置函数的代码都需要进行相应的修改
∴ 用第一个Message2就可以把这个问题解决掉
"""
class Message1:
    def __init__(self, mid: int, text: str):
        self.__id: int = mid
        self.__text: str = text

    @property
    def id(self) -> int:
        return self.__id

    @property
    def text(self) -> str:
        return self.__text

    def __repr__(self):
        return f"{self.__class__.__name__}({self.id}, {self.text})"

    def __eq__(self, other):
        if other.__class__ != self.__class__:   # isinstance(other, self):
            return NotImplemented
        else:
            return ((self.id, self.text) == (other.id, other.text))

    def __ne__(self, other):
        result = self.__eq__(other)
        if result is NotImplemented:
            return NotImplemented
        else:
            return not result

    def __hash__(self):
        return hash((self.__class__, self.id, self.text))

    def __lt__(self, other):
        if other.__class__ != self.__class__:
            return NotImplemented
        else:
            return self.id < other.id

    def __le__(self, other):
        if other.__class__ != self.__class__:
            return NotImplemented
        else:
            return self.id <= other.id

    def __gt__(self, other):
        if other.__class__ != self.__class__:
            return NotImplemented
        else:
            return self.id > other.id

    def __ge__(self, other):
        if other.__class__ != self.__class__:
            return NotImplemented
        else:
            return self.id >= other.id
@dataclass
class Message2:
    id: int = None
    text: str = None
    age: int = None
if __name__ == '__main__':
    m1 = Message1(2, 'hello 2')
    m2 = Message1(1, 'hello 1')
    m3 = Message2(3, 'hello 3')
    print(m3)
    print(astuple(m3))
    print(asdict(m3))

    print(m3.__dir__())
Message2(id=3, text='hello 3', age=None)
(3, 'hello 3', None)
{'id': 3, 'text': 'hello 3', 'age': None}
['id', 'text', 'age', '__module__', '__annotations__', '__dict__', '__weakref__', '__doc__', '__dataclass_params__', '__dataclass_fields__', '__init__', '__repr__', '__eq__', '__hash__', '__str__', '__getattribute__', '__setattr__', '__delattr__', '__lt__', '__le__', '__ne__', '__gt__', '__ge__', '__new__', '__reduce_ex__', '__reduce__', '__subclasshook__', '__init_subclass__', '__format__', '__sizeof__', '__dir__', '__class__']

通过m3.__dir__()就可以看到经过@dataclass修饰的数据类,自动初始化了很多内置参数,减少了很多代码的工作量

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Kotlin为我们提供了许多内置函数来简化代码编写和提高代码的可读性。下面是一些常用的Kotlin内置函数: 1. apply函数:apply函数允许我们在对象的上下文中执行一系列操作,并返回该对象本身。这对于初始化对象的属性非常有用。 2. also函数:also函数与apply函数似,不同之处在于它返回的是传入的对象,而不是上下文对象本身。它通常用于执行一些附加操作,例如打印日志或进行调试。 3. let函数:let函数允许我们对一个非空的对象执行一系列操作,并返回一个结果。它可以帮助我们避免空指针异常。 4. run函数:run函数允许我们在上下文中执行一系列操作,并返回该上下文的结果。它似于apply函数,但不同之处在于run函数返回的是闭包的结果,而不是上下文对象本身。 5. with函数:with函数允许我们在上下文中执行一系列操作,而无需使用上下文对象的名称。它通常与非空的对象一起使用,以方便地访问对象的属性和方法。 6. takeIf函数:takeIf函数接受一个断言条件作为参数,并返回该对象本身,如果条件为真;否则返回null。这用于根据条件过滤对象。 7. takeUnless函数:takeUnless函数与takeIf函数相反,它接受一个断言条件作为参数,并返回该对象本身,如果条件为假;否则返回null。它也用于根据条件过滤对象。 这些内置函数在Kotlin标准库中定义,可在任何Kotlin项目中使用。它们有助于简化代码,提高开发效率。了解这些函数的用法将使您能够更好地利用Kotlin的语言特性。 请注意,这只是一小部分Kotlin内置函数的介绍。在Kotlin的标准库中还有许多其他有用的函数等待您去探索和使用。希望这些信息对您有所帮助! <span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [Kotlin之内置函数](https://blog.csdn.net/qq_32955807/article/details/128448836)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [Kotlin中内置函数用法和区别总结](https://download.csdn.net/download/weixin_38692928/14029345)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值