首页 >后端开发 >Python教程 >不可变类型与可变类型:赋值何时意味着就地修改?

不可变类型与可变类型:赋值何时意味着就地修改?

DDD
DDD原创
2024-12-16 16:54:11500浏览

Immutable vs. Mutable Types: When Does Value Assignment Mean In-Place Modification?

不可变类型与可变类型:澄清概念

使用编程语言时,理解不可变类型和可变类型之间的区别至关重要。查询中提供的示例提出了有关此概念的问题。

什么构成不可变类型?
不可变类型是指其值一旦创建就无法修改的对象。浮点对象通常被认为是不可变的,如示例所示:

class RoundFloat(float):
    def __new__(cls, val):
        return float.__new__(cls, round(val, 2))

此示例定义了一个扩展浮点类型的类。但是,new 方法不会修改对象创建期间建立的底层浮点值。类似地,示例:

class SortedKeyDict(dict):
    def __new__(cls, val):
        return dict.__new__(cls, val.clear())

创建一个扩展 dict 类型的类,其中 new 在创建时从字典中删除所有键。 RoundFloat 和 SortedKeyDict 都展示了不变性,因为它们的 new 方法不会更改原始值。

可变类型:就地修改
相反,可变类型允许就地修改值。示例:

class SortedKeyDict_a(dict):
    def example(self):
        return self.keys()

定义一个类,该类使用返回键列表的示例方法扩展 dict 类型。然而,字典仍然是可变的,如下所示:

d = (('zheng-cai', 67), ('hui-jun', 68),('xin-yi', 2))
SortedKeyDict_a(d)  # Returns a dictionary without calling example

可变性:值分配与就地修改
不可变类型的行为可能会令人困惑,特别是在考虑时赋值:

x = 5.0
x += 7.0
print x # 12.0

在此示例中,x 是一个浮点对象,它是不可变的。然而,赋值 x = 7.0 似乎改变了它的值。这里的关键区别在于 x 的原始浮点值被分配了一个新值,而不是就地修改。

这种区别也适用于可变类型。考虑以下示例:

s = 'foo'
s += 'bar'
print s # foobar

由于 s 是字符串类型(不可变),因此必须重新分配它以包含“bar”。可以使用可变类型进行就地修改:

x = [1, 2, 3]
x += [3, 2, 1]
print x # [1, 2, 3, 3, 2, 1]

这里,列表 x 通过附加另一个列表来扩展。这些示例强调了类型的可变性与就地修改功能有关。

以上是不可变类型与可变类型:赋值何时意味着就地修改?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn