OpenRTMFP/Cumulus Primer(17)AMF解析之AMFReader(续1)
来源:互联网 发布:公司免费记账软件 编辑:程序博客网 时间:2024/05/17 03:43
OpenRTMFP/Cumulus Primer(17)AMF解析之AMFReader(续1)
- Author: 柳大·Poechant(钟超)
- Email: zhongchao.ustc#gmail.com (#->@)
- Blog: Blog.CSDN.net/Poechant
- Date: April 24th, 2012
1 解析 AS3 Null
void AMFReader::readNull() {
先 reset 一下是惯例,就像糗百上的割一样。。
reset();
AMF 数据类型
AMF::Type type = followingType();
如果是 Null,跳过该字节,并返回
if (type == AMF::Null) { reader.next(1); return; }
判断错误
ERROR("Type %.2x is not a AMF Null type",type);}
2 解析 AS3 Number
double AMFReader::readNumber() {
惯例
reset();
类型
AMF::Type type = followingType();
Null 会被悲催的跳过
if (type == AMF::Null) { reader.next(1); return 0; }
不是 Number 呀 :(
if (type != AMF::Number) { ERROR("Type %.2x is not a AMF Number type",type); return 0; }
跳过该字节吧
reader.next(1);
返回吧,返回之前还用到 Poco::BinaryReader 的运算符,注意 AS3 中的 Number 就是 C++ 的 double
double result; reader >> result; return result;}
3 解析 AS3 Integer
Int32 AMFReader::readInteger() {
reset、类型:
reset(); AMF::Type type = followingType();
Null 的话。。
if (type == AMF::Null) { reader.next(1); return 0; }
不是 Integer 或者 Number 的话。。。
if (type != AMF::Integer && type != AMF::Number) { ERROR("Type %.2x is not a AMF Integer type",type); return 0; }
跳过吧。
reader.next(1);
终于是 Number 了。
if (type == AMF::Number) { double result; reader >> result; return (Int32)result; }
读一个变长的 32 位无符号整数:
// Forced in AMF3 here! UInt32 value = reader.read7BitValue();
如果大于 3.5 个字节所能表示的最大无符号整数值(268435455是0xFFFFFFF),则减去 0x2FFFFFFF(这还不是太理解,有能解释的朋友给留个言,或者发email给我^_^)
if (value > 268435455) value -= (1 << 29); return value;}
4 解析 AS3 Boolean
bool AMFReader::readBoolean() {
惯例:
reset(); AMF::Type type = followingType();
如果是 Null。。
if (type == AMF::Null) { reader.next(1); return false; }
居然不是 Boolean 的话。。
if (type != AMF::Boolean) { ERROR("Type %.2x is not a AMF Boolean type",type); return false; }
如果是 AMF3 的话,返回 true 或者 false:
if (_amf3) return reader.read8()== AMF3_FALSE ? false : true;
不是 AMF3 就是 AMF0 喽:
reader.next(1); return reader.read8()==0x00 ? false : true;}
-
转载请注明来自柳大的CSDN博客:Blog.CSDN.net/Poechant
-
- OpenRTMFP/Cumulus Primer(17)AMF解析之AMFReader(续1)
- OpenRTMFP/Cumulus Primer(16)AMF解析之AMFReader
- OpenRTMFP/Cumulus Primer(18)AMF解析之AMFReader(续2)
- OpenRTMFP/Cumulus Primer(9)AMF解析之BinaryReader/Writer
- OpenRTMFP/Cumulus Primer(14)AMF解析之PacketReader/Writer
- OpenRTMFP/Cumulus Primer(15)AMF解析之数据类型定义
- OpenRTMFP/Cumulus Primer(9)AMF解析之BinaryReader/Writer
- OpenRTMFP/Cumulus Primer(11)IO 管理之IO流
- OpenRTMFP/Cumulus Primer(1)入门介绍与部署CumulusServer
- OpenRTMFP/Cumulus Primer(1)入门介绍与部署CumulusServer
- OpenRTMFP/Cumulus Primer(12)IO管理之IO流(续)
- OpenRTMFP/Cumulus Primer(5)CumulusServer启动流程分析(续1)
- OpenRTMFP/Cumulus Primer(5)CumulusServer启动流程分析(续1)
- OpenRTMFP/Cumulus Primer(3)图解CumulusEdge原理
- OpenRTMFP/Cumulus Primer(4)CumulusServer启动流程分析
- OpenRTMFP/Cumulus Primer(10)IO 管理之流缓冲区
- OpenRTMFP/Cumulus Primer 入门(3)图解CumulusEdge原理
- OpenRTMFP/Cumulus Primer(4)CumulusServer启动流程分析
- 合并(归并)排序 算法原理与实现
- 根据进程名取进程ID,句柄,最前端显示
- 进程间应用system.out和system.err传递数据
- 第十周实验报告任务3
- 无ARP欺骗的嗅探技术
- OpenRTMFP/Cumulus Primer(17)AMF解析之AMFReader(续1)
- js 新浪微博的统计字数方法
- 把DLL文件打包进EXE的技巧(C#)
- 虚拟列表控件
- 索引
- R树
- Spring IOC三种注入方式比较
- 黑马程序员-骑士飞行棋
- 驾照理论考试总结