jiang江江 2017-12-26 13:31 采纳率: 33.3%
浏览 962
已结题

请问这个是不是Apache的一个错误?

在Apache源码中,\srclib\apr\fileio\win32\open.c这个文件中的160行,有这么一段代码这里的file是一个const char 星的值,n是他的长度,r是另一个字符串的长度,感觉他的本意是想让两个字符串的长度小于256,但是在处理两个字符串的长度大于256时,操作明显不当,让n-256-r,会取得负值,这样就会读到file内存前面的内容,这不就是错误了吗?

        if (n > 256 - r) {
            file += n - 256 - r;
            n = 256;
            /* skip utf8 continuation bytes */
            while ((*file & 0xC0) == 0x80) {
                ++file;
                --n;
            }
        }
  • 写回答

2条回答 默认 最新

  • AnyAdapter 2017-12-26 13:44
    关注

    file += n - 256 - r;
    等价与
    file = file + n - 256 - r;
    说明file本身还有长度,前面的代码应该是有对file初始化的,你可以联系前面的代码看一下是如何处理file的。

    评论

报告相同问题?

悬赏问题

  • ¥15 LiBeAs的带隙等于0.997eV,计算阴离子的N和P
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘
  • ¥15 来真人,不要ai!matlab有关常微分方程的问题求解决,
  • ¥15 perl MISA分析p3_in脚本出错
  • ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
  • ¥15 ubuntu虚拟机打包apk错误
  • ¥199 rust编程架构设计的方案 有偿
  • ¥15 回答4f系统的像差计算
  • ¥15 java如何提取出pdf里的文字?
  • ¥100 求三轴之间相互配合画圆以及直线的算法