指针引用(OK)和指向引用的指针(ERROR)

#include<iostream>
using namespace std;

int main(){
	int a = 100;
	cout << "1:" << a << endl;
	int &ar = a;
	cout << "2:" << ar << endl;
	int *p = &a;
	cout << "a address(p) :" << p << " 3:" << *p << endl;
	
	int *pr2 = &ar;//引用变量的地址(其实没取到引用变量的地址),还是原来变量的地址

	cout << "ar address(pr2):" << pr2 << " 4. *pr2:" << *pr2 << endl;//结果取引用的地址和a的地址一样
	/**

	pointerAndReference.cpp:15:13: error: invalid conversion from 'void*' to 'int*'
[-fpermissive]
  int *pr3 = &&ar;
	*/
	//int *pr3 = &&ar;
	//cout << pr3 << endl;
	
	/*
	 cannot declare pointer to 'int&'
	*/
	//int &* pr1 = ar;//error
	// cannot declare pointer to 'int&'
	//int &* pr = p; //指向引用的指针 error 也许是因为不能对引用取地址!
	int *& pr = p;//OK ,指针引用相当于指针的别名
	cout << "address(pr):" << pr << " 5:" << *pr << endl;
	int ** pr4 = &p;
	cout << "pointer address:" << pr4 << " &p:" << &p << endl;

	return 0;

}
C:\Users\jackz\Desktop\codes\cpp>g++ pointerAndReference.cpp

C:\Users\jackz\Desktop\codes\cpp>a
1:100
2:100
a address(p) :0x28feec 3:100
ar address(pr2):0x28feec 4. *pr2:100
address(pr):0x28feec 5:100
pointer address:0x28fee8 &p:0x28fee8


以下是模拟实现打印作业任务管理的代码: ```c #include <stdio.h> #include <stdlib.h> #define ERROR 1 #define OK 0 #define OVERFLOW 1 typedef int QElemType; typedef int Status; #define MAXQSIZE 100 //最大队列长度 typedef struct { QElemType *base; // 动态分配存储空间 int front; // 头指针,若队列不空,指向队列头元素 int rear; // 尾指针,若队列不空, //指向队列尾元素的下一个位置 } SqQueue; Status InitQueue(SqQueue *Q) { Q->base = (QElemType*)malloc(MAXQSIZE * sizeof(QElemType)); if (!Q->base) exit(OVERFLOW); //存储分配失败 Q->front = Q->rear = 0; return OK; } int QueueLength(SqQueue Q) { return (Q.rear - Q.front + MAXQSIZE) % MAXQSIZE; } Status EnQueue(SqQueue *Q, QElemType e) { if ((Q->rear + 1) % MAXQSIZE == Q->front) return ERROR; //队列满 Q->base[Q->rear] = e; Q->rear = (Q->rear + 1) % MAXQSIZE; return OK; } Status DeQueue(SqQueue *Q, QElemType *e) { if (Q->front == Q->rear) return ERROR; //队列空 *e = Q->base[Q->front]; Q->front = (Q->front + 1) % MAXQSIZE; return OK; } Status PrintQueue(SqQueue Q) { if (Q.front == Q.rear) { printf("队列为空!\n"); return OK; } printf("队列中的元素为:"); int i = Q.front; while (i != Q.rear) { printf("%d ", Q.base[i]); i = (i + 1) % MAXQSIZE; } printf("\n"); return OK; } int main() { SqQueue Q; QElemType e; InitQueue(&Q); printf("请输入打印作业的数量:"); int n; scanf("%d", &n); for (int i = 1; i <= n; i++) { int job; printf("请输入第%d个打印作业需要的打印时间:", i); scanf("%d", &job); if (EnQueue(&Q, job) == ERROR) { printf("队列已满,打印作业%d无法加入队列!\n", i); } } printf("\n打印作业队列中共有%d个打印作业。\n", QueueLength(Q)); PrintQueue(Q); printf("\n开始打印作业...\n"); while (Q.front != Q.rear) { DeQueue(&Q, &e); printf("打印作业%d已完成打印,剩余打印作业数量:%d\n", e, QueueLength(Q)); } printf("所有打印作业已完成打印。\n"); return 0; } ``` 以上程序实现了一个打印作业任务管理的队列,用户可以输入打印作业的数量和每个打印作业需要的打印时间,程序将打印作业加入队列,并依次完成打印作业。在队列满的情况下,无法将新的打印作业加入队列,并输出相应的提示信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值