免费注册 查看新帖 |

Chinaunix

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

c语言可以用字符串作为数组的索引名(键名)吗? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-11-22 20:03 |显示全部楼层 |倒序浏览
初学c,从php转过来的,试了许多方法,貌似都不行,哪位高人给指点下

论坛徽章:
0
2 [报告]
发表于 2008-11-22 20:18 |显示全部楼层
我又想到一个方法,先试下,如果可行我发上来

论坛徽章:
0
3 [报告]
发表于 2008-11-22 20:27 |显示全部楼层
原帖由 tyc611 于 2008-11-22 20:07 发表
你要实现的是map,自己定义一个二维数组(或者类似的),然后自己查找

自己的想法又失败了,还是走到大家的提示上来.map是c里的还是c++里的?

论坛徽章:
0
4 [报告]
发表于 2008-11-22 20:37 |显示全部楼层
原帖由 happy_fish100 于 2008-11-22 20:32 发表
当然是C++的了

那没戏了,只学了c.我再慢慢找,大家在c内有现成的解决办法请告诉我

论坛徽章:
0
5 [报告]
发表于 2008-11-22 23:56 |显示全部楼层
使用了变通的方法实现了.我的需求是从mysql里读取的数据,希望能象php一样调用,例如
$res->fields['name']

现在我把我在c里变通实现的思路大体讲一下.就是把mysql读出来的结果封装进一个数组里.然后定义一个函数,姑且起名
char *res_data(char *name)

然后我在main里res_data(name)这样调用这个函数,name就是键名.函数对用name和之前从mysql里读出的字段名对比,一旦对上了,就提取出对应的字段里的数据,以字符串数组指针的形式返回.对比的时候使用的是遍历的方法,不适合大量字段的,不过对于操作数据库是足够了.
char *res_data(char *name) {
    int i, j;
    j = 0;
&nbsp;&nbsp;&nbsp;&nbsp;for(i=0;i<14 & j==0;i++) {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;printf("name : %s\n", name);
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;printf("sql_array[0][%d] : %s\n", i, sql_array[0][i]);
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if(strcmp(sql_array[0][i], name)==0) {
//&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;printf("123456789\n");

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;sql_data = sql_array[1][i];
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;j = 1;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}
&nbsp;&nbsp;&nbsp;&nbsp;}

&nbsp;&nbsp;&nbsp;&nbsp;return sql_data;
}

论坛徽章:
0
6 [报告]
发表于 2008-11-23 00:01 |显示全部楼层
只是初步完成了,还需要不断完善,我初学c,上下许多定义没有写出来,如果有人看不懂,但是也急需这种功能,可以回复本帖,我整理出详细的.
上例中
sql_array[0][i]
存储的是mysql表里的字段名,对应的
sql_array[1][i]
里是数据.
这只是对应从数据库读出一条数据的情况,实际上如果把sql_array定义为4维数组就可以处理多条数据了.程序也需要继续进化.上下文的变量都没有给出,只是提供了一个变通实现的思路.大家如果有其他思路也请提出.

[ 本帖最后由 yahoo21cn 于 2008-11-23 00:02 编辑 ]

论坛徽章:
0
7 [报告]
发表于 2008-11-23 00:31 |显示全部楼层
原帖由 ivhb 于 2008-11-23 00:14 发表


原来是这个需求啊
用hsearch就可以了

多谢,我搜索并研究一下,现在的手段有点繁琐,又更好的就好了
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP