免费注册 查看新帖 |

Chinaunix

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

[C] 求教ADT如何typedef [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-08-22 22:57 |只看该作者 |倒序浏览
一个简单的栈ADT,但是想在一个程序里面使用——即能操作int也能操作char

但是一个单独的程序没法两次typedef来定义Item,现在暂时用void *来实现,即:

typedef void * Item;

请问还有没有什么好的方法,虽然这样使用ADT接口是简单统一了,但是在使用者来说反而复杂了,需要进行int *或者char *的操作,本来简单的譬如:STACKpush(STACKpop() + STACKpop())之类的问题,还要写成这样:
  1. t = malloc(sizeof *t);
  2.             *t = *(int *)STACKpop() + (*(int *)STACKpop());
  3.             STACKpush(t);
复制代码
ADT简单实现如下(算法:C语言实现)
  1. #include <stdlib.h>

  2. #include "Item.h"
  3. #include "STACK.h"

  4. static Item *s;
  5. static int N;

  6. void STACKinit(int maxN)
  7. {
  8.     s = malloc(maxN * sizeof(Item));
  9.     N = 0;
  10. }

  11. int STACKempty(void)
  12. {
  13.     return N==0;
  14. }

  15. void STACKpush(Item item)
  16. {
  17.     s[N++] = item;
  18. }

  19. Item STACKpop(void)
  20. {
  21.     return s[--N];
  22. }
复制代码

论坛徽章:
1
白羊座
日期:2013-09-18 22:02:26
2 [报告]
发表于 2012-08-28 17:46 |只看该作者
  1. typedef void * Item;
复制代码
这个东西是要在你实际使用时定义成你需要的类型的

比如你需要将其定义成int行就直接
  1. typedef int Item;
复制代码

论坛徽章:
0
3 [报告]
发表于 2012-08-29 11:36 |只看该作者
file3 发表于 2012-08-28 17:46
这个东西是要在你实际使用时定义成你需要的类型的

比如你需要将其定义成int行就直接


我的意思是在同一个程序里面

typedef int Item;
typedef char Item;

没有办法同时存在,就必须做成typedef void *Item;

论坛徽章:
14
巨蟹座
日期:2013-11-19 14:09:4615-16赛季CBA联赛之青岛
日期:2016-07-05 12:36:0515-16赛季CBA联赛之广东
日期:2016-06-29 11:45:542015亚冠之全北现代
日期:2015-07-22 08:09:472015年辞旧岁徽章
日期:2015-03-03 16:54:15巨蟹座
日期:2014-12-29 08:22:29射手座
日期:2014-12-05 08:20:39狮子座
日期:2014-11-05 12:33:52寅虎
日期:2014-08-13 09:01:31巳蛇
日期:2014-06-16 16:29:52技术图书徽章
日期:2014-04-15 08:44:01天蝎座
日期:2014-03-11 13:06:45
4 [报告]
发表于 2012-08-29 12:03 |只看该作者
类似于这样

#define _TYPE_ int
#include <template.h>

#define _TYPE_ char
#include <template.h>

STACKinit_int( ... );

STACKinit_char( ... );

论坛徽章:
1
白羊座
日期:2013-09-18 22:02:26
5 [报告]
发表于 2012-08-30 09:04 |只看该作者
bruceteen 发表于 2012-08-29 12:03
类似于这样

#define _TYPE_ int


佩服,我原来还想使用static在某个文件内进行局部特例话。

如果是您这样的,可以直接在编译期完成特例,而且特例化的约束会更小。

可以直接

#define _TYPE_ int
声明结构体。
#undef _TYPE

#define _TYPE_ int
再声明结构体。
#undef _TYPE

论坛徽章:
36
子鼠
日期:2013-08-28 22:23:29黄金圣斗士
日期:2015-12-01 11:37:51程序设计版块每日发帖之星
日期:2015-12-14 06:20:00CU十四周年纪念徽章
日期:2015-12-22 16:50:40IT运维版块每日发帖之星
日期:2016-01-25 06:20:0015-16赛季CBA联赛之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之福建
日期:2016-04-07 11:25:2215-16赛季CBA联赛之青岛
日期:2016-04-29 18:02:5915-16赛季CBA联赛之北控
日期:2016-06-20 17:38:50技术图书徽章
日期:2016-07-19 13:54:03程序设计版块每日发帖之星
日期:2016-08-21 06:20:00
6 [报告]
发表于 2012-08-30 14:32 |只看该作者
可以用宏加个类型的参数,也可以用普通函数加个参数来做类型判断
  1. #include <stdlib.h>

  2. #include "Item.h"
  3. #include "STACK.h"

  4. static void *s;    //changed to void*
  5. static int N;

  6. #define STACKinit(maxN, type)\
  7. {\
  8.     s = malloc(maxN * sizeof(type));\
  9.     N = 0;\
  10. }\

  11. #define STACKempty()  (0==N)

  12. #define STACKpush(item, type)\
  13. {\
  14.     ((type*)s)[N++] = item;\
  15. }

  16. #define STACKpop(type)  ((type*)s)[--n];
复制代码

论坛徽章:
36
子鼠
日期:2013-08-28 22:23:29黄金圣斗士
日期:2015-12-01 11:37:51程序设计版块每日发帖之星
日期:2015-12-14 06:20:00CU十四周年纪念徽章
日期:2015-12-22 16:50:40IT运维版块每日发帖之星
日期:2016-01-25 06:20:0015-16赛季CBA联赛之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之福建
日期:2016-04-07 11:25:2215-16赛季CBA联赛之青岛
日期:2016-04-29 18:02:5915-16赛季CBA联赛之北控
日期:2016-06-20 17:38:50技术图书徽章
日期:2016-07-19 13:54:03程序设计版块每日发帖之星
日期:2016-08-21 06:20:00
7 [报告]
发表于 2012-08-30 14:33 |只看该作者
普通函数的类似,另外楼主这个没有栈顶栈底的判断,改下吧
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP