(原創) 如何讓pointer指向pointer自己? (C/C++) (C)
Abstract
在小明思考 的{Just for fun} 如何让指针指向自己 ,他用了C++寫了這個有趣的題目,我用C語言改寫了一次。
Introduction
題目很簡單,有一個pointer,希望他指的是自己這個pointer,也就是最後希望cout << &p << endl和cout << p << 結果一樣。
原作用C++的template function來做
1
/*
2
(C) OOMusou 2007 http://oomusou.cnblogs.com
3
4
Filename : pointer2self_CPP.cpp
5
Compiler : Visual C++ 8.0 / BCB 6.0 / gcc 3.4.2 / ISO C++
6
Description : Demo how to point to pointer itself
7
Release : 05/24/2007 1.0
8
*/
9
#include <iostream>
10
11
using namespace std;
12
13
template <typename T>
14
inline void p2self(T* &p) {
15
p = (T*)&p;
16
}
17
18
int main() {
19
int *pi;
20
cout << &pi << endl;
21
22
p2self(pi);
23
24
cout << pi << endl;
25
}

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

執行結果


這個程式相當好懂,由於C++多了reference,所以可以少用一個pointer,最後再用泛型的(T*)轉成原本型別的pointer。
若用C語言寫,由於要處理各種型別的pointer,有兩種方法,一種使用macro,一種使用void*
1
/*
2
(C) OOMusou 2007 http://oomusou.cnblogs.com
3
4
Filename : pointer2self_C.cpp
5
Compiler : Visual C++ 8.0 / BCB 6.0 / gcc 3.4.2 / ISO C++
6
Description : Demo how to point to pointer itself
7
Release : 05/24/2007 1.0
8
*/
9
#include "stdio.h"
10
11
//#define p2self(p) (*p) = (void*)&(*p)
12
void p2self(void** p) {
13
(*p) = (void*)&(*p);
14
}
15
16
int main() {
17
int* pi;
18
printf("%x\n",&pi);
19
20
p2self((void**)&pi);
21
22
printf("%x\n",pi);
23
}

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

執行結果


11行

使用的是macro
12行



使用的是void*
為什麼是void**呢?原本是int*,為了處理所有型別的pointer變成void*,為了使pointer用pass by reference傳遞,所以多了一個pointer變成void **。
Conclusion
這沒什麼實際的用途,誠如原作者所說,just for fun,但看到了function template如何用macro或void*來實做,但若以可讀性來說,可以看出C++還是比C語言可讀性來的高。
Reference
{Just for fun} 如何让指针指向自己