免费注册 查看新帖 |

Chinaunix

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

[C] 这个函数里面的if() 是不是写的太罗嗦了? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-07-19 11:51 |只看该作者 |倒序浏览
下面这个代码是在wget的源码中看到的,
1、定义了两个指针p, cp 指向buffer[]数组,一个是static char 一个是 char,这样的好处是啥子?
2、感觉定义的static char *p = buffer;在这里定义有点多余,感觉用不上;
3、if语句中,为啥写成了p + size >= buffer + sizeof (buffer),  直接用  size >= sizeof(buffer) 不是一样的么?
4、后面来了句 p += size;这个是搞啥子的啊?

发现完全不知道这个函数里面这么的意思了,请求解惑,谢谢。
  1. /* Return a string that contains S with "no-" prepended.  The string
  2.    is NUL-terminated and allocated off static storage at Wget
  3.    startup.  */

  4. static char *
  5. no_prefix (const char *s)
  6. {
  7.   static char buffer[1024];
  8.   static char *p = buffer;

  9.   char *cp = p;
  10.   int size = 3 + strlen (s) + 1;  /* "no-STRING\0" */
  11.   if (p + size >= buffer + sizeof (buffer))
  12.     abort ();

  13.   cp[0] = 'n', cp[1] = 'o', cp[2] = '-';
  14.   strcpy (cp + 3, s);
  15.   p += size;
  16.   return cp;
  17. }
复制代码

论坛徽章:
0
2 [报告]
发表于 2013-07-19 13:21 |只看该作者
p比较的是指针,你改了之后是比较长度。
你考虑一下,no_prefix 这个函数多次调用会怎么样。

论坛徽章:
2
程序设计版块每日发帖之星
日期:2015-06-17 22:20:00每日论坛发贴之星
日期:2015-06-17 22:20:00
3 [报告]
发表于 2013-07-19 13:34 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
36
CU大牛徽章
日期:2013-09-18 15:24:20NBA常规赛纪念章
日期:2015-05-04 22:32:03牛市纪念徽章
日期:2015-07-24 12:48:5515-16赛季CBA联赛之辽宁
日期:2016-03-30 09:26:4715-16赛季CBA联赛之北控
日期:2016-03-30 11:26:2315-16赛季CBA联赛之广夏
日期:2016-05-20 15:46:5715-16赛季CBA联赛之吉林
日期:2016-05-24 11:38:0615-16赛季CBA联赛之青岛
日期:2016-05-30 13:41:3215-16赛季CBA联赛之同曦
日期:2016-06-23 16:41:052015年亚洲杯之巴林
日期:2015-02-03 15:05:04CU大牛徽章
日期:2013-09-18 15:24:52CU十二周年纪念徽章
日期:2013-10-24 15:46:53
4 [报告]
发表于 2013-07-19 13:58 |只看该作者
p是静态的局部变量,这样写才可可重入,至于pm说这样的写法有问题,就不懂了

论坛徽章:
7
数据库技术版块每日发帖之星
日期:2015-08-08 06:20:00数据库技术版块每日发帖之星
日期:2015-08-29 06:20:00数据库技术版块每日发帖之星
日期:2015-08-29 06:20:00数据库技术版块每日发帖之星
日期:2015-09-18 06:20:00数据库技术版块每周发帖之星
日期:2015-11-06 19:56:51数据库技术版块每日发帖之星
日期:2016-01-22 06:20:00数据库技术版块每日发帖之星
日期:2016-02-05 06:20:00
5 [报告]
发表于 2013-07-19 15:07 |只看该作者
1.  static 变量只初始化一次,所以第2,3,。。。,n次进入函数时,p的指向就是 buffer + n 了
2.  参考1
3. p + size >= buffer + sizeof (buffer) 的含义是 buffer中剩余的空间是不是能存下字符串s,size >= sizeof(buffer)  这里sizeof(buffer) 是常量 1024, 所以需要根据上次的位置算一下
4. p+=size表示下次存储的起始位置

论坛徽章:
2
程序设计版块每日发帖之星
日期:2015-06-17 22:20:00每日论坛发贴之星
日期:2015-06-17 22:20:00
6 [报告]
发表于 2013-07-19 15:07 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
1
摩羯座
日期:2013-12-19 10:04:07
7 [报告]
发表于 2013-07-19 15:14 |只看该作者
回复 6# pmerofc

越界是未定义行为 但是
要改的话 不能直接 size >= sizeof(buffer)
size 这个数值应该是多次进入函数累计的

buffer + sizeof(buffer) - p > size
  

论坛徽章:
2
程序设计版块每日发帖之星
日期:2015-06-17 22:20:00每日论坛发贴之星
日期:2015-06-17 22:20:00
8 [报告]
发表于 2013-07-19 15:21 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
1
摩羯座
日期:2013-12-19 10:04:07
9 [报告]
发表于 2013-07-19 15:35 |只看该作者
回复 8# pmerofc

我说得有点乱
代码第18行 p+=size;
还有就是5楼的回复

你都看看 应该能理解 size > sizeof(buffer) 如果要写这句 那么这个size 应该是累加前面进入这个函数的每一个size
   

论坛徽章:
2
程序设计版块每日发帖之星
日期:2015-06-17 22:20:00每日论坛发贴之星
日期:2015-06-17 22:20:00
10 [报告]
发表于 2013-07-19 16:07 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP