指針有兩個(gè)屬性:指向變量/對(duì)象的
地址和長(zhǎng)度
但是指針只存儲(chǔ)地址,長(zhǎng)度則取決于指針的類(lèi)型
編譯器根據(jù)指針的類(lèi)型從指針指向的地址向后尋址
指針類(lèi)型不同則尋址范圍也不同,比如:
int*從指定地址向后尋找4字節(jié)作為變量的存儲(chǔ)單元
double*從指定地址向后尋找8字節(jié)作為變量的存儲(chǔ)單元
1.void指針是一種特別的指針
void *vp
//說(shuō)它特別是因?yàn)樗鼪](méi)有類(lèi)型
//或者說(shuō)這個(gè)類(lèi)型不能判斷出指向?qū)ο蟮拈L(zhǎng)度
2.任何指針都可以賦值給void指針
type *p;
vp=p;
//不需轉(zhuǎn)換
//只獲得變量/對(duì)象地址而不獲得大小
3.void指針賦值給其他類(lèi)型的指針時(shí)都要進(jìn)行轉(zhuǎn)換
type *p=(type*)vp;
//轉(zhuǎn)換類(lèi)型也就是獲得指向變量/對(duì)象大小
轉(zhuǎn):http://icoding.spaces.live.com/blog/cns!209684E38D520BA6!130.entry
4.void指針不能復(fù)引用
*vp//錯(cuò)誤
因?yàn)関oid指針只知道,指向變量/對(duì)象的起始地址
而不知道指向變量/對(duì)象的大小(占幾個(gè)字節(jié))所以無(wú)法正確引用
5.void指針不能參與指針運(yùn)算,除非進(jìn)行轉(zhuǎn)換
(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要先強(qiáng)制轉(zhuǎn)換一下,目的是為了讓它先知道要覆蓋的大小.
//P的內(nèi)容竟然給Q的內(nèi)容覆蓋掉了.
cout<<P->id<<" "<<P->fa[0]<<" "<<P->fa[1]<<endl;
return 0;
}