博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
byte[]数组的正则表达式搜索 z
阅读量:2236 次
发布时间:2019-05-09

本文共 995 字,大约阅读时间需要 3 分钟。

在byte[]数组的特定位置进行正则表达式匹配。

为了从硬盘上搜索特定类型的文件,需要根据文件的特征值进行匹配。

对于已掌握文件结构的文件,采用hard-code的方式进行匹配;这样速度快;

对于未掌握文件结构的文件,根据文件的特征数据,使用正则表达式进行匹配。缺点是匹配速度慢。但是相对于阅读或破解每种文件的数据结构,可以节约开发时间。

由于C#中的正则表达式引擎仅提供了对字符串的正则匹配,而我们从硬盘上读取的数据是byte[]类型,所以需要添加对byte[]数据进行正则匹配的支持。

另外,文件的特征值应(否则就很难称之为“特征”了)出现在固定的位置,所有要指定在特定位置进行正则匹配。

using System.Text.RegularExpressions;        //byte[]数组Grep搜索,确定在指定offset处是否匹配正则表达式字符串//buffer:要搜索的byte[]数组//regex:要匹配的正则表达式字符串//offset:buffer数组的偏移        public static bool BinaryRegex(byte[] buffer, string regex,int offset)        {            List
charList = new List
(); foreach (byte b in buffer) { charList.Add((char)b); } string bString = new String(charList.ToArray()); Match match = Regex.Match(bString,regex); if (match.Success && match.Index == offset) return true; else return false; }

 

转载于:https://www.cnblogs.com/zeroone/p/8983630.html

你可能感兴趣的文章
Oracle PL/SQL语言初级教程之完整性约束
查看>>
PL/SQL学习笔记
查看>>
如何分析SQL语句
查看>>
结构化查询语言(SQL)原理
查看>>
SQL教程之嵌套SELECT语句
查看>>
日本語の記号の読み方
查看>>
计算机英语编程中一些单词
查看>>
JavaScript 经典例子
查看>>
判断数据的JS代码
查看>>
js按键事件说明
查看>>
AJAX 初次体验!推荐刚学看这个满好的!
查看>>
AJAX 设计制作 在公司弄的 非得要做出这个养的 真晕!
查看>>
Linux 查看文件大小
查看>>
Java并发编程:线程池的使用
查看>>
redis单机及其集群的搭建
查看>>
Java多线程学习
查看>>
检查Linux服务器性能
查看>>
Java 8新的时间日期库
查看>>
Chrome开发者工具
查看>>
【LEETCODE】102-Binary Tree Level Order Traversal
查看>>