void指標
指標有兩個屬性:指向變數/對象的地址和長度
但是指標只儲存地址,長度則取決於指標的類型
編譯器根據指標的類型從指標指向的地址向後定址
指標類型不同則定址範圍也不同,比如:
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要先強制轉換一下,目的是為了讓它Crowdsourced Security Testing道要覆蓋的大小.
//P的內容竟然給Q的內容覆蓋掉了.
cout<<P->id<<" "<<P->fa[0]<<" "<<P->fa[1]<<endl;
return 0;
}