1. 程式人生 > >void指針(void *的用法)

void指針(void *的用法)

不知道 == 覆蓋 ont 參與 world! 強制 med stdlib.h

指針有兩個屬性:指向變量/對象的地址長度
但是指針只存儲地址,長度則取決於指針的類型
編譯器根據指針的類型從指針指向的地址向後尋址
指針類型不同則尋址範圍也不同,比如:
int*從指定地址向後尋找4字節作為變量的存儲單元
double*從指定地址向後尋找8字節作為變量的存儲單元

1.void指針是一種特別的指針
void *vp
//說它特別是因為它沒有類型
//或者說這個類型不能判斷出指向對象的長度

2.任何指針都可以賦值給void指針
type *p;
vp=p;
//不需轉換
//只獲得變量/對象地址而不獲得大小

3.void指針賦值給其他類型的指針時都要進行轉換
type *p=(type*)vp;
//轉換類型也就是獲得指向變量/對象大小
轉:http://icoding.spaces.live.com/blog/cns!209684E38D520BA6!130.entry

4.void指針不能復引用
*vp//錯誤
因為void指針只知道,指向變量/對象的起始地址
而不知道指向變量/對象的大小(占幾個字節)所以無法正確引用

5.void指針不能參與指針運算,除非進行轉換
(type*)vp++;
//vp==vp+sizeof(type)



#include<iostream>
#include<stdlib.h>
#include<string>
using namespace std;
typedef struct tag_st
{
char id[10];
float fa[2];
}ST;
//我在程序裏面這樣使用的
int main()
{
ST * P=(ST *)malloc(sizeof(ST));
strcpy(P->id,"hello!");
P->fa[0]=1.1;
P->fa[1]=2.1;

ST * Q=(ST *)malloc(sizeof(ST));
strcpy(Q->id,"world!");
Q->fa[0]=3.1;
Q->fa[1]=4.1;
void ** plink=(void **)P;
*((ST *)(plink)) = * Q; //plink要先強制轉換一下,目的是為了讓它先知道要覆蓋的大小.


//P的內容竟然給Q的內容覆蓋掉了.
cout<<P->id<<" "<<P->fa[0]<<" "<<P->fa[1]<<endl;
return 0;
}

void指針(void *的用法)