0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

nuere-簡單小巧快速的字符串解析庫

jf_wN0SrCdH ? 來源: Rust語言中文社區(qū) ? 2023-08-14 09:54 ? 次閱讀

neure是一個簡單小巧的字符串解析庫, 我在開發(fā)aopt時為了優(yōu)化編譯時間而開發(fā)的替代regex的庫. 目前代碼架構非常簡單, 性能上比regex更快, 和nom的速度不相上下. 設計上參考了regex.Readme有一個和regex比較的代碼,可以嘗試一下.

https://github.com/araraloren/neure

補充一個和nom例子比較的代碼,開啟lto=fat時性能不相上下

use neure::*;
use nom::{
    bytes::{tag, take_while_m_n},
    combinator::map_res,
    sequence::tuple,
    IResult,
};

#[derive(Debug, PartialEq)]
pub struct Color {
    pub red: u8,
    pub green: u8,
    pub blue: u8,
}

fn from_hex(input: &str) -> Result {
    u8::from_str_radix(input, 16)
}

fn is_hex_digit(c: char) -> bool {
    c.is_digit(16)
}

fn hex_primary(input: &str) -> IResult<&str, u8> {
    map_res(take_while_m_n(2, 2, is_hex_digit), from_hex)(input)
}

fn hex_color(input: &str) -> IResult<&str, Color> {
    let (input, _) = tag("#")(input)?;
    let (input, (red, green, blue)) = tuple((hex_primary, hex_primary, hex_primary))(input)?;

    Ok((input, Color { red, green, blue }))
}

fn main() -> Result<(), Box> {
    let mut storer = SpanStorer::new(1);
    let color_str = "#2F14DF";
    let parser = |storer: &mut SpanStorer, str: &str| -> Result<(), neure::Error> {
        let pound = neure!('#');
        let hex = neure!(['0' - '9' 'A' - 'F']{2});
        let mut ctx = CharsCtx::default().with_str(str);

        ctx.reset();
        ctx.try_mat(£)?;
        ctx.try_cap(0, storer, &hex)?;
        ctx.try_cap(0, storer, &hex)?;
        ctx.try_cap(0, storer, &hex)?;
        Ok(())
    };

    measure(100000, 100000, || {
        if parser(storer.reset(), color_str).is_ok() {
            let mut strs = storer.substrs(color_str, 0).unwrap();
            assert_eq!(
                Color {
                    red: u8::from_str_radix(strs.next().unwrap(), 16).unwrap(),
                    green: u8::from_str_radix(strs.next().unwrap(), 16).unwrap(),
                    blue: u8::from_str_radix(strs.next().unwrap(), 16).unwrap(),
                },
                Color {
                    red: 47,
                    green: 20,
                    blue: 223,
                }
            );
            1
        } else {
            0
        }
    });

    measure(100000, 100000, || {
        if hex_color("#2F14DF").unwrap()
            == (
                "",
                Color {
                    red: 47,
                    green: 20,
                    blue: 223,
                },
            )
        {
            1
        } else {
            0
        }
    });
    Ok(())
}

pub fn measure(n: usize, size: usize, mut f: impl FnMut() -> i32) {
    use std::Instant;

    let start = Instant::now();
    let mut sum = 0;
    for _ in 0..n {
        sum += f();
    }
    let time = start.elapsed();
    println!(
        "Size = {size}, Cost time {} with test {} times: {} --> {}",
        time.as_secs_f64(),
        n,
        time.as_secs_f64() / n as f64,
        sum,
    );
}

審核編輯:湯梓紅

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 字符串
    +關注

    關注

    1

    文章

    589

    瀏覽量

    20951
  • 代碼
    +關注

    關注

    30

    文章

    4876

    瀏覽量

    69967
  • 編譯
    +關注

    關注

    0

    文章

    674

    瀏覽量

    33559
  • GitHub
    +關注

    關注

    3

    文章

    481

    瀏覽量

    17304

原文標題:【大家的項目】nuere - 簡單小巧快速的字符串解析庫

文章出處:【微信號:Rust語言中文社區(qū),微信公眾號:Rust語言中文社區(qū)】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    實例解析Java字符串內存管理方法

    Java[1]語言為字符串操作提供了豐富的支持,它將字符串封裝在三個類中并提供多種字符串操作接口。在Java應用程序中,由于對字符串的使用量比較高,從而使得其需要消耗較大的堆空間。例如
    發(fā)表于 10-27 10:20 ?1次下載
    實例<b class='flag-5'>解析</b>Java<b class='flag-5'>字符串</b>內存管理方法

    字符串移位包含的問題解決方案

    問題:給定字符串s和t,判斷是否字符串t能通過將s移位后的字符串所包含。 方法一 最簡單的方法就是將s進行循環(huán)移位,再判斷移位后的字符串是否
    發(fā)表于 11-29 10:05 ?1119次閱讀

    什么是復制字符串?Python如何復制字符串

    連續(xù)幾篇文章都在寫 Python 字符串,這出乎我的意料了。但是,有的問題,不寫不行,特別是那種靈機一動想到的問題,最后你發(fā)現(xiàn),很多人根本不懂卻又誤以為自己懂了。那就繼續(xù)刨根問底,探究個明白吧
    發(fā)表于 11-25 10:32 ?3121次閱讀

    strtok拆分字符串

    就是字符格式。有些場景需要使用多個處理器協(xié)同工作,比如單片機+openmv,它們之間需要通信,可以采用字符格式的編碼方式。操作字符串,無非是兩件事兒:生成字符串
    發(fā)表于 01-13 15:46 ?8次下載
    strtok拆分<b class='flag-5'>字符串</b>

    字符串操作

    labview字符串操作
    發(fā)表于 06-28 15:09 ?2次下載

    C語言總結_字符串全方位練習

    C語言字符串全方位練習,涉及知識點:字符串解析、大小寫判斷、字符串插入、字符串刪除、字符串排序、
    的頭像 發(fā)表于 08-14 09:41 ?1707次閱讀

    關于STEP7功能字符串轉換

    libraries---Standard Libray---TI-S7 Converting Blocks) FC編號 功能名稱 描述 FC5 DI_STRING 雙整數(shù)轉字符串 FC16
    的頭像 發(fā)表于 10-10 10:50 ?4676次閱讀

    鏈式存儲字符串簡單實現(xiàn)

    除了順序,還有鏈,所謂鏈,就是鏈式存儲的字符串。
    的頭像 發(fā)表于 01-18 10:51 ?1456次閱讀
    鏈式存儲<b class='flag-5'>字符串</b>的<b class='flag-5'>簡單</b>實現(xiàn)

    python字符串有哪些特定方法

    python字符串序列操作也適用于列表和元組。 python字符串還有獨有方法,即字符串對象的函數(shù),其他對象不可調用,只有字符串對象可調用。
    的頭像 發(fā)表于 02-23 15:02 ?856次閱讀

    字符串的相關知識

    TCL 中的數(shù)據(jù)類型只有一種:字符串。這些字符串可以是字母、數(shù)字、布爾值、標點符號等特殊字符的組合。在某些特殊命令的作用下,字符串可以向其他數(shù)據(jù)類型轉換。下面將系統(tǒng)的講解或回顧下
    的頭像 發(fā)表于 03-29 11:41 ?1283次閱讀

    mysql字符串包含某個字符串

    MySQL是一種開源的關系型數(shù)據(jù)管理系統(tǒng),被廣泛用于構建Web應用程序和其他大型數(shù)據(jù)驅動的應用。在進行MySQL數(shù)據(jù)查詢時,經(jīng)常需要使用字符串包含操作,即判斷一個字符串是否包含另一
    的頭像 發(fā)表于 11-16 14:52 ?4227次閱讀

    MySQL替換字符串函數(shù)REPLACE

    MySQL是目前非常流行的開源數(shù)據(jù)管理系統(tǒng)之一,它具有強大的功能和性能。其中之一的字符串函數(shù)REPLACE,可以用于替換字符串中的指定字符字符串
    的頭像 發(fā)表于 11-30 10:44 ?2000次閱讀

    oracle判斷字符串包含某個字符

    字符串操作是任何編程語言中都非常重要的一部分,Oracle數(shù)據(jù)作為目前最常用的關系型數(shù)據(jù)之一,也提供了豐富的字符串操作函數(shù)和方法。在本文中,我們將詳細
    的頭像 發(fā)表于 12-06 09:53 ?1.6w次閱讀

    字符串字符數(shù)組的區(qū)別

    大多數(shù)編程語言中是一個高級數(shù)據(jù)結構,通常由語言的運行時環(huán)境直接支持。字符串通常以連續(xù)的字符序列存儲,但它們不僅僅是字符簡單集合。字符串對象
    的頭像 發(fā)表于 01-07 15:29 ?795次閱讀

    字符串在數(shù)據(jù)中的存儲方式

    數(shù)據(jù)是現(xiàn)代信息技術中存儲和管理數(shù)據(jù)的核心組件。字符串作為最常見的數(shù)據(jù)類型之一,在數(shù)據(jù)中的存儲方式對其性能和可擴展性有著重要影響。 數(shù)據(jù)類型 固定長度字符串 :如CHAR類型,它為每
    的頭像 發(fā)表于 01-07 15:41 ?555次閱讀

    電子發(fā)燒友

    中國電子工程師最喜歡的網(wǎng)站

    • 2931785位工程師會員交流學習
    • 獲取您個性化的科技前沿技術信息
    • 參加活動獲取豐厚的禮品