免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1410 | 回复: 0
打印 上一主题 下一主题

[C] 关于函数异常处理的困惑 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-10-03 16:21 |只看该作者 |倒序浏览
下面就是一小段简单的代码,作用是返回栈顶的元素,现在的困惑就是当这个栈为空我该怎么处理:abor(),exit()还是其他。
我一般用下面的处理方法,但是这样带来了一个问题,就是栈顶元素无法通过返回值进行返回。

  1. //
  2. typedef struct seqStackNode {
  3.     int top;
  4.     datatype *data;
  5.     int max_len; //error 2 :init with value
  6.     #ifdef __INT_STATCK_WITH_MIN__
  7.     datatype minVal;
  8.     #endif // __INT_STATCK_WITH_MIN__
  9. } seqStack;

  10. //s 表示一个栈
  11. //e表示用来存放返回的栈顶元素的地址
  12. //返回值表示 这个函数的执行状态,成功返回0,失败返回1

  13. int getTop(seqStack *s, datatype *e)
  14. {
  15.     if (isEmpty(s)) {
  16.         return -1;
  17.     }
  18.     #ifdef __INT_STATCK_WITH_MIN__
  19.     if (s->data[s->top] < s->minVal) {
  20.         *e = s->minVal;
  21.         s->minVal = 2*(s->minVal) - s->data[s->top];
  22.     } else {
  23.         *e = s->data[s->top];
  24.     }
  25.     #else
  26.     *e = s->data[s->top];
  27.     #endif // __INT_STATCK_WITH_MIN__
  28.     return 0;
  29. }
复制代码
想请大家提点意见,这个函数该怎么改,才能让其返回值是栈顶元素,同时还能处理好异常情况。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP