以下程式是這樣的
f1() : 函式一將會把他的一個本地變數 記憶體位址傳出
f2() : 函式二,就函式一使用過的 變數記憶體位址 直接指明使用之
main: 主程式,將函式一使用過的 變數記憶體位址 列印出 "內涵值"
有何目的呢?
我們都知道,函式的 本地變數 在退出函式後(組合語言是 ret 返回) 會釋放 "它"
※也就是 f1()
1.那得到這個 變數的記憶體位址 後,可否不經由
宣告變數而使用他呢? (也就是直接用指標指向這個記憶體位址,間接用指標對其讀寫)
2.本地變數 失效後(也就是退出函式後)
其內容如何?
3.當運行別的函式時,這個位址會有何變化?
看過結果後會發現 C/C++ 與其它語言的不同
總之有興趣的網友先試試以下程式再說吧
PHP 語法:
#include <cstdlib>
#include <iostream>
using namespace std;
void f2(int usememaddress)
{
/*
有時候,我們只希望儲存記憶體的位址,然後將之與另一個記憶體位址作比較,
這時候我們並不需要關心型態的問題,我們可以使用void*來宣告指標,例如:
void* ptr;
※ void*表示它儲存的是記憶體位址,但資料型態未知,
所以我們也就不能對它作運算的動作,我們只能對它作比較的動作,
或是將它指定給其它的指標。
*/
void *buf= reinterpret_cast<void*>(usememaddress);
int *p= new (buf)int;
printf("\n新宣告記憶體位址是(1):\t%d",p);
printf("\n內含值是(1):\t\t%d\n",*p);
/*清除並且釋放記憶體*/
delete reinterpret_cast<void*>(usememaddress);
delete p;
printf("\n[delete該記憶體位址後]\n");
printf("\n新宣告記憶體位址是(2):\t%d",p);
printf("\n內含值是(2):\t\t%d\n",*p);
}
int f1()
{
int varIs, memaddress;
char pop[9];
static bool b;
if(b)
varIs=888;
else
varIs=111;
b=!b;
printf("\n變數值是(1):\t\t%d ",varIs);
/*取得varIs記憶體位址 (memaddress)*/
sprintf(pop,"%d", &varIs);
memaddress=atoi(pop);
printf("[該記憶體位址是: %d]",memaddress);
/*當 varIs還未失效時 [離開f1()函式],
在 f2()裡宣告一變數,而此 變數 使用同一個 記憶體位址*/
return memaddress;
}
int main(int argc, char *argv[])
{
int VarMemAddress;
VarMemAddress=f1(); //VarMemAddress是 f1()裡某 int型態變數的 記憶體位址
int *vptr= reinterpret_cast<int*>(VarMemAddress);
printf("\n%d位址之內含值是:\t%d\n", vptr, *vptr);
f2(VarMemAddress);
f1();
printf("\n%d位址之內含值是:\t%d\n", vptr, *vptr);
system("PAUSE");
return EXIT_SUCCESS;
}
續~