switch的跳转表

在进行实验的时候对switch的跳转表不是很理解,所以经过查找资料进行自我总结

我的疑问:

1.跳转表是否是随机生成的?

是随机生成的

2.跳转表的工作原理?

https://blog.csdn.net/wenpinglaoyao/article/details/51099553
https://geekori.com/details.php?que_id=1624

3.跳转表中每个case之间的关系?

跳跃表的性质;

1.由很多层结构组成;
2.每一层都是一个有序的链表,排列顺序为由高层到底层,都至少包含两个链表节点,分别是前面的head节点和后面的nil节点;
3.最底层的链表包含了所有的元素;
4.如果一个元素出现在某一层的链表中,那么在该层之下的链表也全都会出现(上一层的元素是当前层的元素的子集);
5.链表中的每个节点都包含两个指针,一个指向同一层的下一个链表节点,另一个指向下一层的同一个链表节点;

switch中的整数范围在编译器处理的时候是连续分布的,对于没有出现在case中的整数,它在跳转表中的数据就是default时的跳转地址,

猜你喜欢

转载自blog.csdn.net/aurora0_0/article/details/84641358