百科问答小站 logo
百科问答小站 font logo



为什么修改esp寄存器会触发异常? 第1页

  

user avatar   bei-ji-85 网友的相关建议: 
      

题主的想法是:把内存映射的地址换个地方,把新的栈指针指过去。目的是为了动态调整栈的位置吧?

但这种做法不可取,也不可能实现。

首先esp的值不仅仅保存在esp里,换句话说,指向栈上的东西,不仅仅是只有esp,比如ebp也是可以用来做寻址的。甚至在内存里,多级指针都是指向旧的内存区域,你不可能也没办法把这些内存里的数据都指向新的栈空间,因为对于内存来说,都是一个一个数值,它是指针,还是一个整型数,没人知道。

所以, 跟权限无关,你这个思路本身就是错的。




  

相关话题

  汇编转换到机器码的时候,寄存器占几个字节? 
  假如当年微软继续开发DOS,今天的DOS会是怎样? 
  linux更新后无法启动时你的心情怎样、第一步怎么做? 
  从技术层面讲,Windows相比Linux有什么优势? 
  Windows 系统的硬件利用率是不是很差? 
  为什么修改esp寄存器会触发异常? 
  操作系统内核态和用户态切换落实到代码层面和运行层面的本质是什么? 
  如果从来不用IE,还有必要打上微软发布的IE安全补丁么? 
  固态硬盘适不适合Linux呀? 
  如何评价 360 安全卫士 for Linux? 

前一个讨论
为什么不把push ebp和mov ebp, esp的操作通过硬件方式做进call指令中?
下一个讨论
linux内核切换成分页模式后,ljmp $__BOOT_CS,$1f 这行代码有什么意思?





© 2025-05-14 - tinynew.org. All Rights Reserved.
© 2025-05-14 - tinynew.org. 保留所有权利