终于找到问题了 在我的代码里有这么一段, char * str ; str = …………………………..; … … … char * k = malloc( strlen( k ) + 1 ) strcpy( k , str ) 而这段代码是在一个动态链接库中的 xxx.so 这样一来,那个strcpy之后,程序的 堆 全被写乱套了,程序就会出来下面这些乱七八糟的错误了。 ###################### *** glibc detected *** /serv/lighttpd1418/sbin/lighttpd: free(): invalid next size (fast): 0×080a27d8 *** ======= Backtrace: ========= /lib/libc.so.6[0xb7e72312] /lib/libc.so.6(cfree+0×89)[0xb7e739c9] /serv/lighttpd1418//lib/mod_stats.so(hash_walk_func+0×360)[0xb7dda210] /serv/lighttpd1418//lib/mod_stats.so(hash_table_map+0×3d)[0xb7ddaf3d] /serv/lighttpd1418//lib/mod_stats.so(stat_table_dump_thread+0×129)[0xb7dd9de9] /lib/libpthread.so.0[0xb7b38e5a] /lib/libc.so.6(clone+0×5e)[0xb7ecc91e] ======= Memory map: ======== 08048000-0806d000 r-xp 00000000 08:08 163125 /serv/lighttpd1418/sbin/lighttpd 0806d000-0806e000 rw-p 00024000 08:08 163125 /serv/lighttpd1418/sbin/lighttpd 0806e000-080b0000 rw-p 0806e000 00:00 0 [heap] b7100000-b7121000 rw-p b7100000 00:00 0 b7121000-b7200000 —p b7121000 00:00 0 b72b6000-b72b7000 —p b72b6000 00:00 0 b72b7000-b7ab6000 rw-p b72b7000 00:00 0 b7ab6000-b7ac9000 r-xp 00000000 08:08 7996 /usr/lib/libz.so.1.2.3 b7ac9000-b7aca000 rw-p 00012000 08:08 7996 /usr/lib/libz.so.1.2.3 b7aca000-b7aee000 r-xp 00000000 08:08 2241 /lib/libm-2.5.so b7aee000-b7af0000 rw-p 00023000 08:08 2241 /lib/libm-2.5.so b7af0000-b7b02000 r-xp 00000000 08:08 2248 /lib/libnsl-2.5.so b7b02000-b7b04000 rw-p 00011000 08:08 2248 /lib/libnsl-2.5.so b7b04000-b7b06000 rw-p b7b04000 00:00 0 b7b06000-b7b0b000 r-xp 00000000 08:08 2222 /lib/libcrypt-2.5.so b7b0b000-b7b0d000 rw-p 00004000 08:08 2222 /lib/libcrypt-2.5.so b7b0d000-b7b34000 rw-p b7b0d000 00:00 0 b7b34000-b7b47000 r-xp 00000000 08:08 2280 /lib/libpthread-2.5.so b7b47000-b7b49000 rw-p 00012000 08:08 2280 /lib/libpthread-2.5.so b7b49000-b7b4b000 rw-p b7b49000 00:00 0 b7b4b000-b7ce9000 r-xp 00000000 08:08 129653 /usr/lib/libmysqlclient_r.so.15.0.0 b7ce9000-b7d2d000 rw-p 0019e000 08:08 129653 /usr/lib/libmysqlclient_r.so.15.0.0 b7d2d000-b7d2e000 rw-p b7d2d000 00:00 0 b7d2e000-b7dc2000 r-xp 00000000 08:08 7538 /usr/lib/libglib-2.0.so.0.1200.11 b7dc2000-b7dc3000 rw-p 00093000 08:08 7538 /usr/lib/libglib-2.0.so.0.1200.11 b7dc3000-b7dce000 r-xp 00000000 08:08 2235 /lib/libgcc_s.so.1 b7dce000-b7dcf000 rw-p 0000a000 08:08 2235 /lib/libgcc_s.so.1 b7dcf000-b7dd1000 r-xp 00000000 08:08 163049 /serv/lighttpd1418/lib/mod_staticfile.so b7dd1000-b7dd2000 rw-p 00002000 08:08 163049 /serv/lighttpd1418/lib/mod_staticfile.so b7dd2000-b7dd6000 r-xp 00000000 08:08 163051 /serv/lighttpd1418/lib/mod_dirlisting.so b7dd6000-b7dd7000 rw-p 00003000 08:08 163051 /serv/lighttpd1418/lib/mod_dirlisting.so b7dd7000-b7e0c000 r-xp 00000000 08:08 163119 /serv/lighttpd1418/lib/mod_stats.so b7e0c000-b7e0d000 rw-p 00034000 08:08 163119 /serv/lighttpd1418/lib/mod_stats.so b7e0d000-b7e0e000 rw-p b7e0d000 00:00 0 b7e0e000-b7f34000 r-xp 00000000 08:08 2210 /lib/libc-2.5.so b7f34000-b7f35000 r–p 00125000 08:08 2210 /lib/libc-2.5.so b7f35000-b7f37000 rw-p 00126000 08:08 2210 /lib/libc-2.5.so b7f37000-b7f3a000 rw-p b7f37000 00:00 0 b7f3a000-b7f3c000 r-xp 00000000 08:08 2229 /lib/libdl-2.5.so b7f3c000-b7f3e000 rw-p 00001000 08:08 2229 /lib/libdl-2.5.so b7f3f000-b7f45000 r-xp 00000000 08:08 2286 /lib/librt-2.5.so b7f45000-b7f47000 rw-p 00006000 08:08 2286 /lib/librt-2.5.so b7f47000-b7f4b000 r-xp 00000000 08:08 7646 /usr/lib/libgthread-2.0.so.0.1200.11 b7f4b000-b7f4c000 rw-p 00003000 08:08 7646 /usr/lib/libgthread-2.0.so.0.1200.11 b7f4c000-b7f4d000 r-xp 00000000 08:08 163098 /serv/lighttpd1418/lib/mod_rewrite.so b7f4d000-b7f4e000 rw-p 00000000 08:08 163098 /serv/lighttpd1418/lib/mod_rewrite.so b7f4e000-b7f4f000 r-xp 00000000 08:08 163084 /serv/lighttpd1418/lib/mod_access.so b7f4f000-b7f50000 rw-p 00000000 08:08 163084 /serv/lighttpd1418/lib/mod_access.so b7f50000-b7f51000 r-xp 00000000 08:08 123783 /serv/lighttpd1418/lib/mod_indexfile.so b7f51000-b7f52000 rw-p 00001000 08:08 123783 /s忽略 (core dumped) / *** glibc detected *** /serv/lighttpd1418/sbin/lighttpd: malloc(): memory corruption (fast): 0×080a6c58 *** ======= Backtrace: ========= /lib/libc.so.6[0xb7ed5312] /lib/libc.so.6[0xb7ed7637] /lib/libc.so.6(__libc_malloc+0×85)[0xb7ed8d35] /serv/lighttpd1418//lib/mod_stats.so(counter_incr+0×99)[0xb7e3d2b9] /serv/lighttpd1418//lib/mod_stats.so(counter_incr_matchtable+0×57)[0xb7e3d347] /serv/lighttpd1418//lib/mod_stats.so(counter_process_browsers+0×53)[0xb7e3d3c3] /serv/lighttpd1418//lib/mod_stats.so[0xb7e3db65] /serv/lighttpd1418/sbin/lighttpd(plugins_call_handle_uri_clean+0×5a)[0×805fe2a] /serv/lighttpd1418/sbin/lighttpd(http_response_prepare+0×2ff)[0×804fdaf] /serv/lighttpd1418/sbin/lighttpd(connection_state_machine+0×2f1)[0×8052b11] /serv/lighttpd1418/sbin/lighttpd(main+0×10a0)[0×804e760] /lib/libc.so.6(__libc_start_main+0xdc)[0xb7e86ebc] /serv/lighttpd1418/sbin/lighttpd[0×804d331] 在网上没找到一点关于这个问题的解释。

转载于:https://www.cnblogs.com/qtchina/archive/2010/06/20/1761204.html

写出一个超强的lighttpd模块相关推荐

  1. linux mysql 不稳定_linux,mysql:今天写出一个十分弱智的bug!

    今天写出一个十分弱智的bug,记录一下,提醒自己以后别这种犯错,不怕丢人哈~ 在写一个分页查询记录的sql时,要根据添加的时间逆序分页输出,之前的写法是酱紫: select record.a, y.c ...

  2. 今天写出一个十分弱智的 bug!

    来源:cnblogs.com/supercj/p/10333918.html 今天写出一个十分弱智的bug,记录一下,提醒自己以后别这种犯错,不怕丢人哈~ 在写一个分页查询记录的sql时,要根据添加的 ...

  3. 怎样写出一个较好的高速排序程序

    写出一个较好的高速排序程序 高速排序是经常使用的排序算法之中的一个,但要想写出一个又快又准的使用程序,就不是那么简单了 须要注意的事项 首先要写正确.通常使用递归实现.其递归相当于二叉树展开,因此假设 ...

  4. 写出一个缓存系统的伪代码001

    /*** 写出一个缓存系统的伪代码*/ public class CacheDemo {private Map<String, Object> map = new HashMap<S ...

  5. 给定一个n节点二叉树,写出一个O(n)时间的非递归的过程,将该树每个结点的关键字输出(算法导论第三版第十章10.4-5)

    给定一个n节点二叉树,写出一个O(n)时间的非递归的过程,将该树每个结点的关键字输出.要求除该树本树的存储空间外只能使用固定量的额外存储空间,且过程中不得修改该树,即使是暂时的修改也不允许. (算法导 ...

  6. 给定一个n节点的二叉树,写出一个O(n)时间非递归过程,将该树每个节点关键字输出,可以使用一个栈作为辅助数据结构(算法导论第十章10.4-3)

    给定一个n节点的二叉树,写出一个O(n)时间非递归过程,将该树每个节点关键字输出,可以使用一个栈作为辅助数据结构 (算法导论第十章10.4-3) template<typename T> ...

  7. 给定一个n节点的二叉树,写出一个O(n)时间递归过程,将该树每个节点关键字输出(算法导论第十章10.4-2)

    给定一个n节点的二叉树,写出一个O(n)时间递归过程,将该树每个节点关键字输出 (算法导论第十章10.4-2) #include <iostream> template<typena ...

  8. 如何写出一个较好的快速排序程序

    写出一个较好的快速排序程序 快速排序是常用的排序算法之一,但要想写出一个又快又准的使用程序,就不是那么简单了 需要注意的事项 首先要写正确.通常使用递归实现.其递归相当于二叉树展开,因此如果要用迭代实 ...

  9. 用c语言写出一个金字塔

    如何用c语言写出一个金字塔 #define _CRT_SECURE_NO_WARNINGS 1#include<stdio.h> int main(){int i;//用户想要的层数int ...

最新文章

  1. bzoj3295:[CQOI2011]动态逆序对
  2. Matab 读取修改 XML
  3. git 创建 本地 裸 仓库
  4. 算法导论系列:分治算法
  5. Hybris Storefront里如何给用户绑定手机号
  6. php多个文件上传代码,PHP单文件上传类或多文件上传类源码
  7. linux文件目录的操作
  8. 【Java 数据结构】二叉树的遍历和基本操作
  9. fot mac matlab_Matlab for Mac
  10. 计算机无法访问iTunes,PC端itunes识别不了iphone怎么办 itunes无法识别插入iPhone解决方法...
  11. 网页使用中文字体的两种解决方案
  12. 如何在公众号添加网站链接
  13. 世界杯 叮当 机器人 树莓派_世界杯营销大战,移动互联网谁捧起了大力神杯
  14. 类的初始化以及实例化
  15. Three.js——天空盒
  16. 微型计算机硬件配置主要包括,2012年会计证考试微型计算机的基本构成3
  17. [机缘参悟-88]:什么是平台?国家、公司、家庭、硬件、软件、应用?
  18. 京东校招2017届应届生java研发岗,面试一,感想
  19. 判断点是否在圆上(java)
  20. 【J2EE】JSP简介

热门文章

  1. 精度87%!业内首个动静统一的图像分割套件重磅推出
  2. 一些真诚的学习经验和生活感悟
  3. 进化算法_遗传算法相关资料
  4. CVPR新规严禁审稿期间公开宣传论文,可发arXiv,LeCun:疯了吧!
  5. 综述:目标检测二十年
  6. 【每日一算法】独特的电子邮件地址
  7. leveldb源码分析:Open启动流程
  8. 最长不含重复字符的子字符串
  9. 进程的介绍(概念、作用)
  10. linux系统版本间的区别是什么?内核又是什么