一、拼接或截取字符串
1. slice
此方法用来提取一个字符串,并返回一个新的字符串
参数:
1 start,表示从该索引处开始提取字符串的字符(包括),如果为负数则从后开始计算
2 end,表示从该索引处结束提取字符串(不包括),如果省略则一直提取到字符串末尾,如果为负数从后开始计算
// slice(start, last) // 从start开始截取,last结束
let str = 'tom_li';
console.log(str.slice(3)); //'_li'
console.log(str.slice(-5, -3)); //'om'
console.log(str.slice(1, 3)); //'om'
console.log(str.slice(0, 3)); //'tom'
2. concat
用于将一个或多个字符串拼接起来,返回拼接后的新字符串
参数:可以有多个,用来拼接字符串
说明:此方法效率并不高,用“+”或者“模板字符串代替比较好
const str = 'tom';
console.log(str.concat('_', 'li'));// tom_li
console.log(str.concat('_', 'li', '-'));// tom_li-
console.log(str.concat('_', 'li', '-', 'haha'));// tom_li-haha
3. substring
此方法和slice方法功能相同都是提取一个字符串,并返回提取到的字符串
参数:
1 start,表示从该索引处开始提取字符串的字符(包括)
2 end,表示从该索引处结束提取字符串(不包括)
3 上述两个参数:如果为负数或者NaN则都会被当做0,如果大于字符串的长度则会被当做字符串的长度来计算,如果 start 大于 end,则 substring 的执行效果就像两个参数调换了一样
// substring(start, end)
let str = 'tom_li';
console.log(str.substring(-1, 3)); //'tom'
console.log(str.substring(3, -1)); //'tom'
二、删除字符串
trim
删除一个字符串两端的空白字符,并返回删除后的新字符串,不会改变原有字符串
let str = 'tom_li';
console.log(str.trim()); //'tom_li'
三、改变字符串
1. toLowerCase
此方法没有参数,会将调用该方法的字符串值转为小写形式,并返回
let str = 'TOM';
console.log(str.toLowerCase()); // tom
2. toUpperCase
此方法没有参数,会将调用该方法的字符串值转为大写形式,并返回
let str = 'tom';
console.log(str.toLowerCase()); // TOM
3. replace
可以将一个替换值替换字符串的一部分,返回替换后的新字符串
参数:
1)一个字符串中要被替换的子字符串或者正则表达式,默认值替换第一个,可以在正则表达式中设置全局模式,来替换所有匹配的子字符串
2)一个替换值
let str = 'tom_li';
// replace('替换值', '被替换的值')
console.log(str.replace(/o/g, 'c')); //"tcm_li"
console.log(str.replace('o', 'c'));
4. split
可以使用一个指定的分隔符来将字符串拆分成数组,返回一个数组
参数:
1)分隔符,可以为一个字符串也可以为正则表达式,为空的话则将每个字符都拆分。默认全局拆分
2)拆分的长度(可选),为一个整数用来限制拆分的个数,如果超过了这个数量则新数组中不返回剩下的文本
let str = 'tom_li';
console.log(str.split(' ')); //['tom_li']
console.log(str.split('_')); //['tom', 'li']
四、查询字符串
1. charAt
从一个字符串中返回指定的字符
参数:index,介于0~length-1之间的整数,默认为0
let str = 'tom_li';
console.log(str.charAt(0)); //'t'
console.log(str.charAt(1)); //'o'
console.log(str.charAt(2)); //'m'
2. includes
判断字符串中是否包含指定字符,包含则返回true,不包含则返回false
参数:subStr,指定的字符串
let str = 'tom_li';
console.log(str.includes('tom')); //true
console.log(str.includes('fire')); //flase
3. indexOf
判断字符串中是否包含指定字符,如果包含则返回该字符索引的位置(查找到了立即返回),如果不包含则返回-1
参数:subStr,指定的字符串
let str = 'tom_li';
console.log(str.indexOf('tom')); //0
console.log(str.indexOf('om')); //1
console.log(str.indexOf('m_')); //2
console.log(str.indexOf('fire')); //-1
4. lastIndexOf
用法和indexOf基本相同,区别是lastIndexOf()是从后往前查找
let str = 'tom_li';
console.log(str.lastIndexOf('tom')); //0
console.log(str.lastIndexOf('om')); //1
console.log(str.lastIndexOf('m_')); //2
console.log(str.lastIndexOf('fire')); //-1
5. search
使用正则表达式查找指定字符串,如果找到则返回首次匹配成功的索引,没有找到则返回-1
参数:一个正则表达式,如果传入一个非正则表达式则会隐式的将其转换为正则表达式对象
let str = 'tom_li';
console.log(str.search('tom')); //0
console.log(str.search('om')); //1
console.log(str.search(/o/)); //1
console.log(str.search(/m/)); //2
6. match
返回一个字符串匹配正则表达式的结果,如果未设置全局匹配,则会返回第一个完整匹配及其相关的捕获组,捕获组中包含有groups、index、input等属性。
参数:一个正则表达式,如果传入一个非正则表达式则会隐式的将其转换为正则表达式对象
let str = 'tom_li';
console.log(str.match(/t/));
//['t', index: 0, input: 'tom_li', groups: undefined]
console.log(str.match(/o/));
//['o', index: 1, input: 'tom_li', groups: undefined]
console.log(str.match(/om/));
//['om', index: 1, input: 'tom_li', groups: undefined]
console.log(str.match(/tom/));
//['tom', index: 0, input: 'tom_li', groups: undefined]
console.log(str.match(/l/g));
//['l']
服务器托管,北京服务器托管,服务器租用 http://www.fwqtg.net
本文主要分享如何快速上手ARM汇编开发的经验、汇编开发中常见的Bug以及Debug方法、用的Convolution Dephtwise算子的汇编实现相对于C++版本的加速效果三方面内容。 前言 神经网络模型能够在移动端实现快速推理离不开高性能算子,直接使用AR…