【zz】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 
#include 
#include 
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=P; 
*((ST *)(plink)) = * Q; //plink要先强制转换一下,目的是为了让它先知道要覆盖的大小. 
//P的内容竟然给Q的内容覆盖掉了. 
cout<id<<" "<fa[0]<<" "<fa[1]<
return 0; 
}

补全代码 先来先服务进程调度算法 运行环境: Dev c++ 算法思想:  先来先服务进程 (FCFS)调度算法则是从当前就绪队列中选出一个最先来的进程,将处理机分配给它,使它立即执行并一直执行到完成 核心数据结构: typedef struct data{ int hour; int min; }time; typedef struct node{ int id;//编号 char name[20];//名字 time arrive;//到达时间 int zx;//执行时间; time start;//开始时间 time finish;//完成时间 int zz;//周转时间=执行完成时间-到达就绪队列时间 double zzxs;//带权周转时间=周转时间/执行时间 struct node* next; }linknode; typedef linknode* linklist; typedef struct{ linklist front; linklist rear; }queue; //队列 程序主体框架: //函数名:init 参数:无 queue* init(){ //函数功能:初始化队列,返回队列指针 } //函数名:insert 参数:Queue *cc, node *x void enqueue(queue* cc,linklist s){ //函数功能:尾插入队 } //函数名:dele 参数:Queue *cc void dequeue (queue* cc){ //功能:队首结点出队 } //函数名:input 参数:Queue *cc void input(queue* cc){ //功能:实现作业队列的输入 } //函数名:sort参数:Queue *cc void sort(queue* cc){ //函数功能:对到达时间进行排序 } //函数名:solve_FCFS参数:Queue *cc void solve_FCFS(queue* cc){ //函数功能:实现先来先服务调度算法 } int main() { while(true) { int op; printf("请输入操作(1:开始进程调度;0:结束进程)"); scanf("%d",&op); if(op==0) break; queue *cc; linklist ll; cc = init(cc); input(cc); ll=sort(cc); enqueuer(cc,ll) solve_FCFS(cc); } return 0; } 测试用例1: 5001 p1 9:40 20 5004 p4 10:10 10 5005 p5 10:05 30 5002 p2 9:55 15 5003 p3 9:45 25 测试用例2: 5001 p1 19:40 20 5002 p4 10:10 10 5003 p5 10:05 30 5004 p2 9:55 15 5005 p3 9:45 25 5006 p6 11:40 20 5007 p8 12:10 10 5008 p9 13:05 30 5009 p10 19:55 15 5010 p7 7:15 15
最新发布
04-03
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值