左边不是一个指针吗?那*x不是是x指针指向的值。两者为什么类型相等?
int Pop(SeqStack * S, StackElementType *x)
{ if(S->top==-1) /*栈为空*/
return(FALSE);
else
{*x= S->elem[S->top];
S->top--; /* 修改栈顶指针 */
return(TRUE);
}
}
*x= S->elem[S->top];这句话为什么要加一个*呀?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- 东京小M 2023-02-11 16:45关注
*x 在这里被称为取地址符,它是一个操作符,用于获取指针指向的地址的值。
在这个代码片段中,S->elem[S->top] 是一个栈的顶部元素的值,而 *x 则是一个指针变量,它指向一个存储该元素的位置。
用这种方式取出顶部元素的值,并将其赋值给 x,因此在函数的结尾,x 的值将是函数弹出的栈顶部元素的值。
请注意,用这种方式获取值仅适用于指针变量。
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 多址通信方式的抗噪声性能和系统容量对比
- ¥15 winform的chart曲线生成时有凸起
- ¥15 msix packaging tool打包问题
- ¥15 finalshell节点的搭建代码和那个端口代码教程
- ¥15 Centos / PETSc / PETGEM
- ¥15 centos7.9 IPv6端口telnet和端口监控问题
- ¥20 完全没有学习过GAN,看了CSDN的一篇文章,里面有代码但是完全不知道如何操作
- ¥15 使用ue5插件narrative时如何切换关卡也保存叙事任务记录
- ¥20 海浪数据 南海地区海况数据,波浪数据
- ¥20 软件测试决策法疑问求解答