addr 与 offset 区别
生活随笔
收集整理的這篇文章主要介紹了
addr 与 offset 区别
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
一、相同點
1、addr 和 offset 操作符都是獲得操作數的偏移地址;
2、addr 和 offset 的處理都是先檢查處理的是全局還是局部變量,若是全局變量則把其地址放到目標文件中。
二、不同點
1、addr??? 偽操作符,只能用在 invoke 偽指令語句中;
2、offset 偽操作符可以用在任何可能涉及偏移地址的指令(當然包括 invoke 偽指令)并想獲取操作數偏移地址的場合中;
3、addr 不能處理向前引用(即 addr 引用的操作數必須在使用 addr 前就得定義或聲明),而offset 則能(不管引用的操作數是
其前或其后定義或聲明);
所謂向前引用是指:標號的定義是在invoke??? 語句之后,比如在如下的例子:?
invoke??? MessageBox,NULL,??? addr??? MsgBoxText,addr??? MsgBoxCaption,MB_OK??? //引用MsgBoxText、MsgBoxCaption 在先
......???
MsgBoxCaption??? db??? "Iczelion??? Tutorial??? No.2",0??? //定義或聲明 MsgBoxCaption 在 addr 后
MsgBoxText??? db??? "Win32??? Assembly??? is??? Great!",0??? //定義或聲明 MsgBoxText 在 addr 后
如果您是用??? addr??? 而不是??? offset??? 的話,那??? MASM??? 就會報
4、addr 是運行階段在堆棧中分配內存空間,offset 是編譯階段由編譯器解釋。因此,addr 可以處理局部變量而 offset 則不能。
5、addr 如果檢查到待處理的變量是局部變量,就在執行 invoke 語句前產生如下指令序列:???
lea??? eax,operand
push??? eax?
因為 lea 指令能夠在運行時決定標號的有效地址,所以有了上述指令序列,就可以保證??? invoke??? 的正確執行了。
總結:為了避免出現錯誤,建議除在局部變量中引用 addr 操作符外,其它場合使用 offset。
說明:某些文章中對 addr 和 offset 所引用的對象僅用了“變量或標號”,我是用“操作數”來闡述的,本人的觀點是:
變量或標號感覺上包含的概念過窄,比如結構、函數等等,因此,覺得使用操作數好像感覺準確些
1、addr 和 offset 操作符都是獲得操作數的偏移地址;
2、addr 和 offset 的處理都是先檢查處理的是全局還是局部變量,若是全局變量則把其地址放到目標文件中。
二、不同點
1、addr??? 偽操作符,只能用在 invoke 偽指令語句中;
2、offset 偽操作符可以用在任何可能涉及偏移地址的指令(當然包括 invoke 偽指令)并想獲取操作數偏移地址的場合中;
3、addr 不能處理向前引用(即 addr 引用的操作數必須在使用 addr 前就得定義或聲明),而offset 則能(不管引用的操作數是
其前或其后定義或聲明);
所謂向前引用是指:標號的定義是在invoke??? 語句之后,比如在如下的例子:?
invoke??? MessageBox,NULL,??? addr??? MsgBoxText,addr??? MsgBoxCaption,MB_OK??? //引用MsgBoxText、MsgBoxCaption 在先
......???
MsgBoxCaption??? db??? "Iczelion??? Tutorial??? No.2",0??? //定義或聲明 MsgBoxCaption 在 addr 后
MsgBoxText??? db??? "Win32??? Assembly??? is??? Great!",0??? //定義或聲明 MsgBoxText 在 addr 后
如果您是用??? addr??? 而不是??? offset??? 的話,那??? MASM??? 就會報
4、addr 是運行階段在堆棧中分配內存空間,offset 是編譯階段由編譯器解釋。因此,addr 可以處理局部變量而 offset 則不能。
5、addr 如果檢查到待處理的變量是局部變量,就在執行 invoke 語句前產生如下指令序列:???
lea??? eax,operand
push??? eax?
因為 lea 指令能夠在運行時決定標號的有效地址,所以有了上述指令序列,就可以保證??? invoke??? 的正確執行了。
總結:為了避免出現錯誤,建議除在局部變量中引用 addr 操作符外,其它場合使用 offset。
說明:某些文章中對 addr 和 offset 所引用的對象僅用了“變量或標號”,我是用“操作數”來闡述的,本人的觀點是:
變量或標號感覺上包含的概念過窄,比如結構、函數等等,因此,覺得使用操作數好像感覺準確些
總結
以上是生活随笔為你收集整理的addr 与 offset 区别的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: PE 学习(七)第七章:资源表
- 下一篇: PE学习(九)第九章:TLS 动态TLS