免费注册 查看新帖 |

Chinaunix

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

[学习] 读文件一行,将内容存入链表 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-07-21 21:42 |只看该作者 |倒序浏览
最近要从文件中读些内容,在其他地方用,写到链表里。
  1. #include<stdio.h>
  2. #include<stdlib.h>
  3. #include<string.h>
  4. struct client_t {
  5.         char        *client;
  6.         struct client_t        *next;
  7. };
  8. int
  9. main (int argc,char **argv)
  10. {
  11.         FILE        *fp;
  12.         char        *str1 = NULL;
  13.         char        *str2 = NULL;
  14.         char        *str3 = NULL;
  15.         char        *str4 = NULL;
  16.         char  *str5 = NULL;
  17.         char        *tmp = NULL;
  18.         char        *string = "helloworld!";
  19.         struct client_t        *head,*p;
  20.         char        buff[100] = {0,};
  21.         int        i = 0;
  22.         int        j = 0;

  23.         j = atoi(argv[1]);
  24.         str5 = argv[2];
  25.         if ((fp = fopen (str5, "r")) == NULL) {
  26.         //if ((fp = fopen ("./cc", "r")) == NULL) {
  27.                   printf("error!");
  28.                   return -1;
  29.           }
  30.         for(i;i<j;i++) {
  31.         fgets(buff,100,fp);
  32.         }
  33.         tmp = buff;
  34.         tmp = strtok_r(tmp, "\n",&str4);
  35.         str3 = strtok_r(tmp," ", &str4);
  36.                 head = malloc(sizeof (struct client_t));
  37.         head->client = str3;
  38.         head->next = NULL;
  39.         for(;str2 = strtok_r (NULL, " ", &str4);) {
  40.                 p = malloc(sizeof (struct client_t));
  41.                 p->client = str2;
  42.                 if (head == NULL) {
  43.                         head = p;
  44.                         head->next = NULL;
  45.                 } else {
  46.                         p->next = head->next;
  47.                         head->next = p;
  48.                 }               
  49.         }       
  50.         while (head) {
  51.                 printf("%s ",head->client);
  52.                 head = head->next;
  53.         }
  54.                        

  55.         pclose (fp);
  56.         return 0;
  57. }
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP