dict

Python内置了字典:dict的支持,dict全称dictionary,在其他语言中也称为map,使用键-值(key-value)存储,具有极快的查找速度。

如果用dict实现,只需要一个“名字”-“成绩”的对照表,直接根据名字查找成绩,无论这个表有多大,查找速度都不会变慢。 

先在字典的索引表里(比如部首表)查这个字对应的页码,然后直接翻到该页,找到这个字。无论找哪个字,这种查找速度都非常快,不会随着字典大小的增加而变慢。

这种key-value存储方式,在放进去的时候,必须根据key算出value的存放位置,这样,取的时候才能根据key直接拿到value

由于一个key只能对应一个value,所以,多次对一个key放入value,后面的值会把前面的值冲掉

如果key不存在,dict就会报错.

要避免key不存在的错误,有两种办法,一是通过in判断key是否存在 'hhh' in d   得到false

二是通过dict提供的get()方法,如果key不存在,可以返回None(注意:返回None的时候Python的交互环境不显示结果。),或者自己指定的value:

要删除一个key,用pop(key)方法,对应的value也会从dict中删除

和list比较,dict有以下几个特点:

  1. 查找和插入的速度极快,不会随着key的增加而变慢;
  2. 需要占用大量的内存,内存浪费多。

而list相反:

  1. 查找和插入的时间随着元素的增加而增加;
  2. 占用空间小,浪费内存很少。

所以,dict是用空间来换取时间的一种方法。

dict可以用在需要高速查找的很多地方,在Python代码中几乎无处不在,正确使用dict非常重要,需要牢记的第一条就是dict的key必须是不可变对象。 

这是因为dict根据key来计算value的存储位置,如果每次计算相同的key得出的结果不同,那dict内部就完全混乱了。这个通过key计算位置的算法称为哈希算法(Hash)。

要保证hash的正确性,作为key的对象就不能变。在Python中,字符串、整数等都是不可变的,因此,可以放心地作为key。而list是可变的,就不能作为key

### `dict with` 的语法与功能 `dict with` 是 Tcl 8.6 版本引入的一个便捷命令,用于简化对嵌套字典的访问和修改操作。它允许在指定的嵌套路径下执行一系列变量操作,将字典中的键自动映射为局部变量,从而避免重复使用 `dict get` 和 `dict set` 命令[^1]。 其基本语法如下: ```tcl dict with varName ?keyList? body ``` - `varName`:表示一个字典变量。 - `keyList`:表示要进入的嵌套路径。 - `body`:在该代码块中,字典的键会被当作局部变量处理。 #### 示例:使用 `dict with` 访问和修改嵌套字典 以下示例展示如何使用 `dict with` 来访问并修改嵌套字典中的值: ```tcl # 创建一个嵌套字典 set config [dict create] dict set config cts skew_group sg0 clocks {clk1 clk2} dict set config cts skew_group sg1 clocks {clk3 clk4} # 使用 dict with 进入嵌套路径 dict with config {cts skew_group sg0} { puts "Current clocks: $clocks" ;# 输出当前时钟列表 set clocks {clk5 clk6} ;# 修改时钟列表 } # 查看修改后的结果 puts "Updated clocks: [dict get $config cts skew_group sg0 clocks]" ``` 执行结果: ``` Current clocks: clk1 clk2 Updated clocks: clk5 clk6 ``` 在 `dict with` 块中,`clocks` 键的值被映射为局部变量,可以直接读取或修改,而无需反复调用 `dict get` 或 `dict set` [^1]。 #### 示例:批量操作嵌套字典中的多个键 `dict with` 也适用于同时操作多个键的情况。例如: ```tcl # 创建一个包含多个配置项的嵌套字典 set user_info [dict create] dict set user_info user john age 28 email john@example.com dict set user_info user jane age 32 email jane@example.com # 使用 dict with 操作 jane 的信息 dict with user_info {user jane} { puts "Name: jane, Age: $age, Email: $email" incr age 1 append email .org } # 查看更新后的 jane 信息 puts "Updated info for jane: [dict get $user_info user jane]" ``` 执行结果: ``` Name: jane, Age: 32, Email: jane@example.com Updated info for jane: age 33 email jane@example.com.org ``` 通过 `dict with` 可以显著减少嵌套字典操作中的冗余代码,并提升代码可读性[^1]。 ### 注意事项 - `dict with` 仅在 Tcl 8.6 及更高版本中可用。 - 在 `body` 块中修改的变量将在执行结束后自动写回原始字典。 - 如果指定的路径不存在,Tcl 会抛出错误。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值