C ++中队列中的错误

时间:2013-04-12 13:52:02

标签: c++

我无法理解这段代码有什么问题。我得到了几个

  

C2227:' - > status'的左边必须指向class / struct / union / generic type

     

C2065:'head':未声明的标识符

  

C3861:'main':找不到标识符

我想访问位于队列头部的项目的状态,并在define.But中给出的3状态之间更改其值。我在尝试访问它时做错了,我不知道。 这是代码:

#define TOTALPACKETS 100
#define WINDOW   5
#define ACK      2
#define PENDING  1
#define NEW      0 


typedef int Item ;
typedef struct node *link;  
struct node{                
    Item data;
    Item status;
    link next; 
};

int QUEUEempty(link head){
    return head==NULL;
}

void QUEUEput(link *head, link *tail, Item data, Item status){
    if (*head==NULL){
                    (*tail)=(link)malloc(sizeof(node)); 
                    (*tail)->data=data;
                    (*tail)->next=NULL;
                    (*tail)->status=NEW;
                    *head=*tail;
                    return;}
    (*tail)->next=(link)malloc(sizeof(node));
    *tail=(*tail)->next;
    (*tail)->data=data;
    (*tail)->next=NULL;
    (*tail)->status=NEW;
    return;
}

Item QUEUEget(link *head){
    Item data=(*head)->data;
    link t=*head;
    *head=(*head)->next;
    free(t);
    return data; 
}

void send(int sPacket){
    (*head)->status=PENDING;//c2227,c2065
    printf("Packet No. %d: %d",sPacket,*head->status);//c2227,c2065
}

void receive(){
    if ((*head)->status==PENDING || (*head)->status=NEW) {//c2227,c2065
        (*head)->status=ACK; //c2227,c2065
          }
    }


int main() { 
    int i,j,k,packets=0;
    link head=NULL,tail=NULL;
    for(i=0;i<TOTALPACKETS;i++){
            QUEUEput(&head,&tail,i,NEW);
            packets++;
    }
    while(!QUEUEempty(head)){   
        for (j=0;j<WINDOW;j++){
            k=TOTALPACKETS-packets;
            send(k);
            receive();
            if ((*head).status==ACK){
            printf("Packet No. %d: %d",k,*head->status); 
            QUEUEget(&head);
            }
        }
    }
return 0;
 }

2 个答案:

答案 0 :(得分:2)

您未能将head传递给send()receive()

关于main(),请参阅Can the arguments of main's signature in C++ have the unsiged and const qualifiers?

答案 1 :(得分:0)

main有一个预定义的表单。您可以使用:

int main ()  /* or: int main(int argc, char* argv[]) */  {

也:

typedef int Item ;
struct node;
typedef node* link;  
struct node{                
    Item data;
    Item status;
    link next; 
};

...
   link head=nullptr,tail=nullptr;
...
   if (head->status==ACK){
        printf("Packet No. %d: %d",k, head->status); 


}

headlink,指向node的指针。此外,您忘记将head传递给sendreceive

void send(int sPacket,link head ){

使用send(sPacket,head)