14, bad address
来源:互联网 发布:麻将棋牌辅助软件 编辑:程序博客网 时间:2024/04/29 11:32
近期程序总是会在启动阶段崩溃,而这是一个网络服务程序,启动时会产生大量的网络通信工作。从现象来看是比较典型的内存溢出导致堆栈被摧毁的问题,即使是用gdb调试也看不到出错的问题点,可以推断出其实是发生了比较严重写非法内存区的动作。
经过不断排查,有一处网络接收逻辑与预期不符。具体现象是服务端已经发送了数据,而接收端recv方法报错,可是套接字状态却是正常的establish。再将errno值与描述打印出来查看是14, bad address提示。此时犯了一个大意的错误,想当然的将其归为套接字地址的异常,直至后来搜索时才发现其实是地址不可写,实际上是指用来接收的缓存区是不可写的。
问题到此发现,再将缓存区内存地址打印出来查看,果然是因为一个作为下标计算的值未经过网络字节序转换而导致数组越界太多。从此处也可以发现系统调用写内存方法其实对缓存区是有一个判断的,推测其原则是若内存区处于内核态则会返回bad address错,防止对系统造成破坏,但如果内存区处于用户态,则系统不会阻止,结果造成程序堆栈被破坏而导致崩溃。
0 0
- 14, bad address
- recvfrom: Bad address
- exec '/system/bin/sh' failed: Bad address (14)
- wpa supplicant ping: bad address
- socket bad address 错误的解决
- 关于错误errno EFAULT:Bad address
- socket bad address 错误的解决
- 解决android网络异常java.net.SocketException: Bad address family
- 网络服务器程序,connect,accept,报错 Bad address
- execvp调用失败,错误信息"Bad address"的原因
- dns 解析错误 :bad address: www.baidu.com
- address
- Address
- address
- address
- address
- address
- Address
- Android_长度单位与内外边距(第一季重制版)
- 初探NO.3—从头到尾聊聊贝叶斯的分类方法2
- 安卓基础(六)
- 内存分析工具 MAT 的使用
- iOS开发的一些奇巧淫技
- 14, bad address
- Project 4:Longest Ordered Subsequence
- java 线程的几种状态
- 多线程同步(C++)C/C++ Runtime函数使用
- Shutting down interface eth1: Error: Device ‘eth1′ NetworkManager/Devices/1 disconnecting failed:
- 艺术签名制作工具v1.0
- php在网站根目录下写文件
- BaseAdapter,这篇博客讲深入一些,实现从本地的JSON文件读取数据
- Android代码优化——使用Android lint工具