首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

【python系统学习07】一张图看懂字典并学会操作

: dictName['name'] # 小石头 嵌套提取 拓展 - 二维嵌套列表值提取方法 同样是用偏移量来获取。...得到列表['apple','pear']后,再继续追加一个偏移量[1]获取得到列表['apple','pear']中第一个元素,打印出'pear' 拓展 - 多维嵌套字典中值提取方法 因为是用键名,...得到"sleep" 拓展 - 列表与字典互相嵌套时值提取方法 举一反三,概念加强版 print(dictName['hobby']['daily'][0][0]) # music 往字典中增加元素 新增键值对要用到赋值语句...只需要在提取基础赋值即可。 ⚠️但可能需要注意,如果键名是字典中已经存在,再这么操作就会直接修改这个键值。...,数组内容自定 3、删除“age” 2、修改“name”值 1、提取出“love”

1.3K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    打造坚实基础:C语言结构体、联合体和枚举

    对齐规则 结构体中每个成员偏移量取决于前面成员类型和内存对齐要求: 1. 结构体第⼀个成员对齐到和结构体变量起始位置偏移量0地址处 2....例题 typedef struct { char a; // 偏移量0 char b; // 偏移量为4 int c; // 偏移量依内存对齐规则可能为8 } MyStruct...偏移量0: char对齐数为1,放在一倍数,对齐8 i对齐数为4,对齐在4倍数上,及12 最大对齐数为8 16为8倍数,所以 s3 大小为16 结构体嵌套 struct S4...; }; struct S s = {0}; s.a = 10; s.b = 12; s.c = 3; s.d = 4; 我们来讨论这块空间是如何开辟 位段中成员在内存中从左向右分配,还是从右向左分配标准尚未定义...位段中成员在内存中从左向右分配,还是从右向左分配标准尚未定义 端序影响在大端和小端架构中,位段物理存储顺序可能不同。

    11310

    C语言进阶-自定义类型:结构体位段枚举联合

    /输出结果:12 解释: 第一个成员c1在与结构体变量偏移量0地址处 对于c2它对齐数为4(int大小为4,小于平台默认值8),该变量要对齐到偏移量为4倍数处,即从偏移量为4位置开始存放...0地址处 c2放在偏移量为1地址处 i放在偏移量为4地址处(对齐到偏移量为对齐数4倍数处) 示例3: struct S3 { double d; char c; int i; }; printf...("%d\n", sizeof(struct S3)); //输出结果:16 解释: 第一个成员d在与结构体变量偏移量0地址处 c放在偏移量为8地址处 i放在偏移量为12地址处(对齐到偏移量为对齐数...:48 解释: 第一个成员c1在与结构体变量偏移量0地址处 s3放在偏移量为8地址处(s3最大对齐数为8) d放在偏移量为24地址处(对齐到偏移量为对齐数8倍数处) 总大小为成员变量最大对齐数倍数...,会导致性能下降 柔性数组 定义: C99 中,结构中最后一个元素允许是未知大小数组,这就叫做柔性数组成员,但结构中柔性数组成员前面必须至少一个其他成员 使用: sizeof 返回这种结构大小不包括柔性数组内存

    69820

    【C结构体】结构体都不会,学啥数据结构(进阶版)

    结构体初始化方式和数组初始化方式很像,结构体成员是否包含数组分别对于一维和二维数组初始化很像 struct Stu { char name[20]; int age; char sex[2...Stu,age) 对齐数:该成员变量字节数和编译器默认对齐数(VS默认是8)中最小值 每一个成员变量都有自己对齐数 结构体内存对齐规则: 第一个成员在与结构体变量偏移量0地址处 从第二个成员开始每个成员变量要对齐到对齐数整数倍处...1.1、平台原因:不是所有的硬件平台都能访问任意地址任意数据,某些硬件平台只能在某些地址处取某些特定类型数据 2、性能原因:,对于访问未对齐内存,处理器需要作两次内存访问;而对齐内存访问仅需要一次访问...,答案:占16个字节 //练习4-结构体嵌套问题 //如果嵌套了结构体,嵌套结构体对齐到自己最大对齐数整数倍中 struct S4 { char c1; 1 struct...位段中最大位数目不能确定。(16位机器最大16,32位机器最大32,写成27,在16位机 器会出问题。 位段中成员在内存中从左向右分配,还是从右向左分配标准尚未定义

    48030

    PHP虚拟机

    ‘last’是数组中操作指令数量,注意这里术语可能令人感到困惑,‘last’看起来像是最后一个操作指令索引,但是这里实际是操作数数量(比最后一个操作数索引大一)。...‘literals’是出现在代码中字面值数组,这个数组是CONST操作数引用。根据ABI①,每个CONST操作数要么储存指向次文本表引用,要么存储相对于其开始偏移量。...如果传递是按值并且$a以前是空,则可能必须生成一堆“未定义索引”通知。如果传递是通过引用的话,我们必须默默地初始化嵌套数组。...R yes no W no yes RW yes yes IS no no UNSET no yes-ish UNSET情况有点奇怪,因为它只能读取现有的偏移量以便写入,并且保留单独未定义偏移量...它会在未定义CV发出通知,并且不会取消操作数取消引用。GET_OPn_ZVAL_PTR_UNDEF()正如我们已经知道那样,它是一种不检查未定义CV变体。

    2.3K10

    自定义类型:结构体(自引用、内存对齐、位段(位域))

    如果嵌套了结构体情况,嵌套结构体成员对齐到自己成员中最大对齐数整数倍处,结构体整体大小就是所有最大对齐数(含嵌套结构体中成员对齐数)整数倍。...printf("c偏移量为%d\n", offset_c); printf("d偏移量为%d\n", offset_d); return 0; } 4.2计算结构体大小示例...S2));//12 return 0; } 4.3嵌套结构体计算: 计算时把嵌套结构体作为一个数据类型去计算,最大对齐数也要与其比较,故有时候会出现最大对齐数为3,5情况(结构体中包含一个char...{ printf("%d %d\n", t.data[0], t.num); // 打印结构体 data 数组第一个元素和 num 值 } // 通过指针传递方式打印结构体内容...6.5位段使用注意事项​ 位段几个成员共有同一个字节,这样有些成员起始位置并不是某个字节起始位置,那么这些位 置处是没有地址

    18310

    C语言——自定义类型之结构体

    将所嵌套结构体元素用一个大括号括起来,和其他元素用逗号隔开即可。 六、结构体内存对齐 1.内存对齐是什么 编译器为程序中每个“数据单元”安排在适当位置。...2.内存对齐规则 1.首先明确:结构体变量在内存中 第一个字节相对于起始位置偏移量0; 第二个字节相对于起始位置偏移量为1; ……以此类推。...2.第一个成员变量在偏移量0地址处; 3.其他成员变量对齐到某数(对齐数)整数倍地址处(偏移量) 3.有嵌套结构体情况内存对齐: 嵌套结构体对齐到自己最大对齐数整数倍处(其他没有变化...) 4.结构体大小是最大对齐数(结构体中所有成员变量(包括嵌套结构体)对齐数最大值)整数倍 5.介绍一个宏 offsetof,可以返回结构体类型中成员变量相对于初始位置偏移量(可以用于判断偏移量...位段中成员在内存中从左向右分配,还是从右向左分配标准尚未定义。 4.

    57610

    C语言_自定义类型详解

    前言 提示:这里可以添加本文要记录大概内容: 一.结构体声明 1.1结构体基础知识 结构是一些值集合,这些值称为成员变量。结构每个成员可以是不同类型变量 数组:一组相同类型集合。...} 上面的两个结构体在声明时候省略掉了结构体标签(tag) 那么在上面代码基础,下面的代码合法吗?...结构体内存对齐规则: 1.结构体第一个成员永远放在相较于结构体变量起始位置偏移量0位置。 2.从第二个成员开始,往后每个成员都要对齐到某个对齐数整数倍。...最大对奇数是:所有成员对齐数中最大值。 如果嵌套了结构体情况,嵌套结构体对齐到自己最大对齐数整数倍处,结构体整体大小就是所有最大对齐数(含嵌套结构体对齐数)整数倍。...3.位段中成员在内存中从左向右,还是从右向左分配标准尚未定义。 4.当一个结构包含两个位段,第二个位段成员比较大,无法容纳于第一个位段剩余位时,是舍弃剩余位还是利用,这是不确定

    18940

    自定义类型详解

    (4) 如果嵌套了结构体情况,嵌套结构体对齐到自己最大对齐数整数倍处,结构体整 体大小就是所有最大对齐数(含嵌套结构体对齐数)整数倍。...有的小伙伴恐怕不知道什么是偏移量,针对结构体情况,偏移量就是相对于你所创建结构体首地址距离,比方说第一天规则,第一个成员要在偏移量0地址处,偏移量0,那么很显然,就是没偏移嘛,就是在首地址存放...("%d", sizeof(struct abc)); } 第一步,将char a放进首地址即偏移量0所在空间,占了1,下一个空间偏移量为1,因int型对齐数为4,故对齐到偏移量为4时存储,存放...要注意一点:先位段空间是按照需要以4个字节( int )或者1个字节( char )方式来开辟。...(3) 位段中成员在内存中从左向右分配,还是从右向左分配标准尚未定义

    14110

    自定义类型之结构体,枚举,联合

    示例四:包含数组结构体 为什么要内存对齐?...int main() { printf("%d %s %f\n", s1.age,s1.name,s1.grade); return 0; } 注意匿名结构体只有在声明结构体时后面定义变量,否则对于一个没有名字结构体...其实结构体可是一个纨绔子弟,"富哥"都是很奢侈,他经常浪费内存!!! 结构体大小计算方法: 内存对齐规则: 第一个成员在与结构体变量偏移量0地址处。从偏移量0地址处向后使用....栗子 示例1:普通结构体 示例1答案: 首先我们将首地址作为偏移量0地址....虽然说位段中":"(冒号)后面的数字不得超过该成员类型所占字节数所换算比特位,但是在不同平台,类型大小是不确定. 位段中成员在内存中从左向右分配,还是从右向左分配标准尚未定义

    51960

    当包容结构体遇见灵活内存管理

    9.内存对齐 1.结构体第⼀个成员对⻬到和结构体变量起始位置偏移量0地址处 2其他成员变量要对⻬到某个数字(对⻬数)整数倍地址处对⻬数=编译器默认⼀个对⻬数与该成员变量⼤⼩较⼩值(VS...4.如果嵌套了结构体情况,嵌套结构体成员对⻬到⾃⼰成员中最⼤对⻬数整数处,结构体整体⼤⼩就是所有最⼤对⻬数(含嵌套结构体中成员对⻬数)整数倍。...• 如果参数 size 为0,malloc⾏为是标准是未定义,取决于编译器。 3.free函数 这边free后没有重置成空指针,free后仍记录原来地址,为啥free不起作用呢?...当是情况1时候,要扩展内存就直接原有内存之后直接追加空间,原来空间数据不发⽣变化 在堆空间另找⼀个合适⼤⼩连续空间来使⽤。这样函数返回是⼀个新内存地址。...a[]; //柔性数组成员 } 3.注意 结构中柔性数组成员前⾯必须⾄少⼀个其他成员。

    8110

    C语言进阶——自定义类型

    且信息类型可以不一样,这就打破了单一数组存储类型固定限制。...4.自引用 自引用是指在结构体中能找到一个和自己类型相同成员,有点像递归,但两者本质不是一个东西。..., s1.next->data[0]);//模拟实现链表 return 0; } 结构体自引用是链表实现必须项,理解透彻了,链表学起来就会很容易  注意: 1.自引用时,其中某个成员变量名必须和结构体类型相同...声明后初始化: 使用前初始化: 当然结构体初始化还有更多玩法,比如下面的指定成员初始化: 嵌套定义: 注意: 1.全局变量默认初始化为0,局部变量为随机值 2.当对局部变量进行指定成员初始化时...,其他成员会初始化为0 3.结构体嵌套定义时,初始化子字符串需要再次进行访问  6.内存对齐   内存对齐是个很有意思东西,为了方便数据读取,设计出了这么个东西。

    33620

    结构体对齐+联合体+位段

    为了深入了解结构体大小事如何计算,即不得不了解结构体对齐。 结构体对齐 要想知道如何计算,就得先知道结构体对齐规则: 第一个成员在与结构体变量偏移量0地址处。...如果嵌套了结构体情况,嵌套结构体对齐到自己最大对齐数整数倍处,结构体整 体大小就是所有最大对齐数(含嵌套结构体对齐数)整数倍 对齐数 = 编译器默认一个对齐数 与 该成员大小较小值。..., c2));//计算c2偏移量 return 0; } 控制台输出结果 由图可以我们分析是正确接下来就再举一个嵌套结构体大小如何计算例子: #include #include...} 画图分析 首先struct s4中第一个成员为char c1,从偏移量0位置存储占用一个字节,第二个成员为结构体,根据结构体对齐规则,嵌套结构体要对齐到自己最大对齐数整数倍处,而struct...而整个结构体大小就是所有最大对齐数(含嵌套结构体对齐数)整数倍,此时结构体偏移量为32正好是所有最大对齐数整数倍。所以结构体大小为32. 控制台输出 为什么存在内存对齐?

    19120

    【C语言】自定义类型详解:结构体、枚举、联合

    )、指针类型和空类型(void),其中基本类型就是我们常见整形、浮点型,而自定义类型则包括数组、结构体、枚举、联合(共用体),数组我们已经非常熟悉了,今天我们主要学习自定义类型中其他几种类型:结构体、...(最大对齐数为所有变量对齐数最大值) 如果嵌套了结构体情况,嵌套结构体对齐到自己最大对齐数整数倍处,结构体整体大小为所有最大对齐数(含嵌套结构体对齐数)整数倍。...第一个成员在与结构体变量偏移量0地址处:所以c1在偏移量0处,且c1占一个字节; 其他成员变量要对齐到它对齐数整数倍地址处:由于 i 对齐数是4,所以 i 只能从偏移量为4位置开始存储...= 结构体成员地址 - 结构体起始地址,比如 struct S1中 i 地址 - 结构体起始地址可以得到结构体成员 i 偏移量等于4;那么如果结构体起始地址在0处,那么结构体成员偏移量...} c1 从0偏移位置开始存储,占一个字节,所以0;struct S3 s3 我们上面已经算出占16个字节,又因为嵌套结构体对齐到自己最大对齐数整数倍处,所以从8整数倍即8偏移处开始存储,所以

    68000

    2021-03-10:一个数组共有 N 个点,序号为0点是起点位置...

    2021-03-10:一个数组共有 N 个点,序号为0点是起点位置,序号为N-1 点是终点位置。现在需要依次0 号点走到 N-1 号点。...但是除了 0 号点和 N-1 号点,他可以在其余 N-2 个位置中选出一个点,并直接将这个点忽略掉,问从起点到终点至少走多少距离?...福哥答案2021-03-10: 数组1,4,-1,3,忽略序号1,数组变成1,-1,3,距离是abs(-2)+4=6;忽略序号2,数组变成1,4,3,距离是3+1=4。...直接忽略一个点只会直接影响到,这个节点前后节点距离。这个 影响距离我们暂且命名为优化距离,将所有节点按顺序组成三个节点集合,通过这种方式只需要通过一次循环便能得到结果。...} if arrLen <= 3 { return abs(arr[arrLen-1] - arr[0]) } i1 := arr[1] - arr[0]

    31410

    使用 WPADPAC 和 JScript在win11中进行远程代码执行1

    如果在其中一个 toString() 回调中元素被添加到之前未定义数组中, 为了更好地理解这个错误及其可利用性,让我们仔细看看我们将溢出缓冲区结构。...数组每个元素大小将是 48 字节(在 64 位构建中),具有以下结构: 抵消 尺寸 描述 0 8 将偏移量 16 处原始 VAR 转换为字符串后指向字符串 VAR 指针 8 4 当前元素索引...指向字符串 VAR 指针被写入偏移量 0。 在偏移量 8 处,写入数组中当前元素索引 根据原始 VAR 类型,在偏移量 40 处写入 0 或 1 看临时缓冲区结构,很多我们并没有直接控制。...如果数组成员是一个字符串,那么在偏移量 0 和 24 处我们将有一个指针,当取消引用时,在偏移量 8 处包含另一个指向我们控制数据指针。然而,这比在大多数情况下对我们有用间接级别要大一级。...但是,如果数组成员是双精度数,那么在偏移量 24(对应于原始 VAR 偏移量 8)处,该数字值将被写入,并且它直接在我们控制之下。

    7.8K950

    C语言:自定义类型——结构体

    数组是一组相同类型元素集合,而结构体同样也是一些值集合,不同是,在结构体中,这些值被称为成员变量,而结构体每个成员变量可以是不同类型变量:如: 标量、数组、指针,甚⾄是其他结构体。...下面就来探究结构体内存对齐。 3.1 对齐规则 1. 结构体第⼀个成员对齐到和结构体变量起始位置偏移量0地址处 2. 其他成员变量要对⻬到某个数字(对齐数)整数倍地址处。...如果嵌套了结构体情况,嵌套结构体成员对⻬到⾃⼰成员中最⼤对⻬数整数倍处,结构 体整体大小就是所有最⼤对⻬数(含嵌套结构体中成员对齐数)整数倍。...通过以上对齐规则,我们来解析刚刚代码: s1:c1在偏移量0地方         c2对齐数是1,放在1倍数处即可,所以可以放在1位置         i对齐数是4,要放在4倍数处,所以从...s2:c1在偏移量0地方         i对齐数是4,要放在4倍数处,所以从4开始放,一直放到7         c2对齐数是1,放在1倍数处即可,所以可以放在8位置  全部放完占用了9

    8510

    结构体,自定义类型

    offsetof是一个宏,可以直接使用,是用来计算结构体成员相较于起始位置偏移量。 上图是S1占用空间示意图,结合下面的规则,我们来分析。 分析:c1是第一个成员,起始位置从0开始。...结构体对齐规则: 第一个成员在与结构体变量偏移量0地址处。...如果嵌套了结构体情况,嵌套结构体对齐到自己最大对齐数整数倍处,结构体整体大小就是所有最大对齐数(含嵌套结构体对齐数)整数倍。 为什么存在内存对齐?...例如,假设a只可能是0,1,2,3,即二进制为00,01,10,11,如果我们不使用位段方式,一个整形就要占32个bit位,实际,位段也会浪费少量空间。...如上图, 实际,c是数组,因为有5个元素,占了五个字节,但他对齐数依旧是1,而i对齐数是4,比5大4倍数最小是8,所以大小就是8。

    13210
    领券