char *FileBuff = new char[sFileLen];...//以上sFileLen、 FileBuff 都已成功賦值,不是問題,略去,從下面開始:char *pPE = FileBuff[0x3C];//取PE頭開始地址char *plen = pPE + 0x50;//指向文件長度unsigned long FileLen = atol(plen);//獲得文件長度,此句取值結果不正確,關鍵!??!...//以下略delete [] FileBuff;問題:編譯已經順利通過,運行也沒有問題,但 FileLen 的結果卻不正確,總是0x0,問題出在哪里?怎么修改才能使FileLen的值正確取到plen 雙字長度的內容?個人感覺好像是 atol() 函數使用的錯誤,但不知道用什么函數合適。這段程序是我編制的一段程序的片段,是要對已讀入內存FileBuff的內容進行相關操作。已知plen指向的位置存儲的是unsigned long 類型的十六進制數據,而不是字符串。這個unsigned long 類型的數據即是我要提取的所謂“文件長度”FileLen,與sFileLen不是一個意思。
1 回答

婷婷同學_
TA貢獻1844條經驗 獲得超8個贊
文件長度信息是隱含的,一般用seek()移動文件讀/寫指針到文件尾部,ftell()函數返回的值才是文件長度(字節數)。
另外
char *FileBuff = new char[sFileLen]; // sFileLen從何而來?
char *pPE = FileBuff[0x3C]; // pPE指向FileBuff[0x3C],就是說必有 sFileLen > 0X3C
char *plen = pPE + 0x50;// 含指0X8C開始的十進制數字串
unsigned long FileLen = atol(plen); // 即使前面都正確,這而也有問題,因為atoi()函數的參數是以'\0'結束的數字串。
- 1 回答
- 0 關注
- 71 瀏覽
添加回答
舉報
0/150
提交
取消