IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 大数据量下的高性能字符串处理 string.Substring优化 -> 正文阅读

[JavaScript知识库]大数据量下的高性能字符串处理 string.Substring优化

有一个txt文本,我需要对他每一行进行遍历,并在匹配的地方做文本截取,

常规情况下肯定就直接用string.Substring,但一测试,耗时直接干到60000ms,也就是60s.

如下面代码中被注释掉的部分,无论是用Substring还是Split都在60s左右.(还不是每一行都要截取)

最后使用了StringBuilder.CopyTo(),直接从60000ms降到25ms

代码中其他的代码作用不用管,测试过,那些逻辑耗时不到5ms,

修改前:


            for (var i = 0; i < lines.Count; i++)
            {
                var instance = lines[i];
                if (i > 0) offset += 2;//+2是换行符
                offsetsDic.Add(i, new KeyValuePair<int, int>(offset, offset += instance.LineText.Length));
                var LineText = instance.LineText.Trim();
                if (instance.LineText.Length > 2 && LineText[0] == '[' && LineText[1] == '@')
                {
                    //var index = LineText.IndexOf(']');
                    //var funName = index > -1 ? LineText.Substring(0, index) : LineText;
                    //var funName = instance.LineText.Split(new char[] { ' ', '\t' }, StringSplitOptions.RemoveEmptyEntries).FirstOrDefault().ToUpperInvariant();
                    fieldLineoffset.Add(i, funName);
                }
                else
                {
                    if (fieldLineoffset.Any())
                        fieldLineoffset.Add(i, fieldLineoffset[i - 1]);
                }
            }

修改后:?text 就是 lines的原文本

var sb = new StringBuilder(text);
            for (var i = 0; i < lines.Count; i++)
            {
                var instance = lines[i];
                if (i > 0) offset += 2;//+2是换行符
                offsetsDic.Add(i, new KeyValuePair<int, int>(offset, offset + instance.LineText.Length));
                var LineText = instance.LineText.Trim();
                if (instance.LineText.Length > 2 && LineText[0] == '[' && LineText[1] == '@')
                {
                    var funName = LineText;
                    var index = LineText.IndexOf(']');
                    if (index > -1)
                    {
                        var chars = new char[instance.LineText.Length - LineText.Length + index];
                        sb.CopyTo(offset + (instance.LineText.Length - LineText.Length), chars, 0, chars.Length);
                        funName = new string(chars);
                    }
                    fieldLineoffset.Add(i, funName);
                }
                else
                {
                    if (fieldLineoffset.Any())
                        fieldLineoffset.Add(i, fieldLineoffset[i - 1]);
                }
                offset += instance.LineText.Length;
            }

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-01-04 13:20:03  更:2022-01-04 13:20:54 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/8 23:45:08-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码