chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

字符串替換研究

京東云 ? 來(lái)源:jf_75140285 ? 作者:jf_75140285 ? 2025-04-02 14:58 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

一、背景

需求非常簡(jiǎn)單,給定一組關(guān)鍵詞,需要將商品名稱中出現(xiàn)過(guò)的關(guān)鍵字替換掉;

如:skuName="HUAWEI Pura 70 Pro 國(guó)家補(bǔ)貼500元 羽砂黑 12GB+512GB 超高速風(fēng)馳閃拍 華為鴻蒙智能手機(jī)" 需要替換成

skuName="HUAWEI Pura 70 Pro 羽砂黑 12GB+512GB 超高速風(fēng)馳閃拍 華為鴻蒙智能手機(jī)" 這里的關(guān)鍵字"國(guó)家補(bǔ)貼500元";

直接skuName.replace("國(guó)家補(bǔ)貼500元", ""),不就可以了嗎?如果是一組,那就循環(huán)替換就完了嘛,再考慮到關(guān)鍵字前綴問(wèn)題,對(duì)這一組關(guān)鍵詞,按字符長(zhǎng)度進(jìn)行排序,先替換長(zhǎng)的關(guān)鍵詞,再替換短的就ok了;

如果這一組關(guān)鍵詞非常多,上千個(gè)怎么辦?真實(shí)場(chǎng)景也是這樣的,一般需要替換的關(guān)鍵詞都是比較多,并且使用String.replace上線后,直接CPU打滿,基本不可用;

這個(gè)字段替換本質(zhì)上與敏感詞過(guò)濾是一樣的原理,針對(duì)敏感詞的深入研究,出現(xiàn)了 Aho-Corasick(AC自動(dòng)機(jī)) 算法;

Aho-Corasick(AC自動(dòng)機(jī))是一種多模式字符串匹配算法,結(jié)合了Trie樹(shù)的前綴匹配能力和KMP算法的失敗跳轉(zhuǎn)思想,能夠在單次文本掃描中高效匹配多個(gè)模式串。其核心優(yōu)勢(shì)在于時(shí)間復(fù)雜度為O(n + m + z)(n為文本長(zhǎng)度,m為模式串總長(zhǎng)度,z為匹配次數(shù)),適用于敏感詞過(guò)濾、基因序列分析等場(chǎng)景。

?

二、方案

針對(duì)這幾種算法進(jìn)行對(duì)比;

字符串替換,定義一個(gè)接口,通過(guò)4個(gè)不同的方案實(shí)現(xiàn),進(jìn)行性能對(duì)比

public interface Replacer {
    String replaceKeywords(String text);
}

2.1 String.replace 方案

這種方案最簡(jiǎn)單,也是關(guān)鍵詞少的時(shí)候,最有效,最好用的;

public class StrReplacer implements Replacer {
    private final List keyWordList;
    public StrReplacer(String keyWords) {
        this.keyWordList = Lists.newArrayList(keyWords.split(";"));
        // 按關(guān)鍵字長(zhǎng)度降序排序,確保長(zhǎng)關(guān)鍵字優(yōu)先匹配
        keyWordList.sort((a, b) -> Integer.compare(b.length(), a.length()));
    }
    /**
    * 替換文本中所有匹配的關(guān)鍵字為空字符串
    */
    @Override
    public String replaceKeywords(String text) {
        String newTxt = text;
        for (String s : keyWordList) {
            newTxt = newTxt.replace(s, "");
        }
        return newTxt;
    }
}

2.2 使用正則替換

String.replace本質(zhì),還是使用正則進(jìn)行替換的,通過(guò)代碼實(shí)現(xiàn)使用編譯好的正則進(jìn)行替換性能會(huì)好于直接使用replace;

String.replace的實(shí)現(xiàn)

public String replace(CharSequence target, CharSequence replacement) {
    return Pattern.compile(target.toString(), Pattern.LITERAL).matcher(
            this).replaceAll(Matcher.quoteReplacement(replacement.toString()));
}

使用正則替換的實(shí)現(xiàn)

public class PatternReplacer implements Replacer {
    // 預(yù)編譯正則表達(dá)式模式
    private final Pattern pattern;
    public PatternReplacer(String keyWords) {
        List keywords = Lists.newArrayList(keyWords.split(";"));
        // 按關(guān)鍵字長(zhǎng)度降序排序,確保長(zhǎng)關(guān)鍵字優(yōu)先匹配
        keywords.sort((a, b) -> Integer.compare(b.length(), a.length()));
        // 轉(zhuǎn)義每個(gè)關(guān)鍵字并用|連接
        String regex = keywords.stream()
                .map(Pattern::quote)
                .collect(Collectors.joining("|"));

        this.pattern = Pattern.compile(regex);
    }

    // 替換方法
    @Override
    public String replaceKeywords(String skuName) {
        return pattern.matcher(skuName).replaceAll("");
    }
}

2.3 使用Aho-Corasick(AC自動(dòng)機(jī)) 算法實(shí)現(xiàn)

java中已有現(xiàn)成的算法實(shí)現(xiàn),源代碼github-robert-bor/aho-corasick,?

引入jar包


    org.ahocorasick
    ahocorasick
    0.6.3

基于 Aho-Corasick 算法的字符串替換實(shí)現(xiàn)

public class AhoCorasickReplacer implements Replacer {
    private final Trie trie;
    public AhoCorasickReplacer(String keyWords) {
        // 構(gòu)建Aho-Corasick自動(dòng)機(jī)
        Trie.TrieBuilder builder = Trie.builder().ignoreOverlaps().onlyWholeWords();
        //trie.caseInsensitive();
        //trie.onlyWholeWords();
        for (String s : keyWords.split(";")) {
            builder.addKeyword(s);
        }
        this.trie = builder.build();
    }
    /**
     * 替換文本中所有匹配的關(guān)鍵字為空字符串
     */
    @Override
    public String replaceKeywords(String text) {
        if (text == null || text.isEmpty()) {
            return text;
        }
        StringBuilder result = new StringBuilder();
        Collection emits = trie.parseText(text); // 獲取所有匹配結(jié)果
        int lastEnd = 0;
        for (Emit emit : emits) {
            int start = emit.getStart();
            int end = emit.getEnd();

            // 添加未匹配的前綴部分
            if (start > lastEnd) {
                result.append(text, lastEnd, start);
            }
            // 跳過(guò)匹配的關(guān)鍵字(即替換為空)
            lastEnd = end + 1; // 注意:end是閉區(qū)間,需+1移動(dòng)到下一個(gè)字符
        }
        // 添加剩余未匹配的后綴部分
        if (lastEnd <= text.length() - 1) {
            result.append(text.substring(lastEnd));
        }
        return result.toString();
    }
}

2.4 自己實(shí)現(xiàn)Trie樹(shù)算法實(shí)現(xiàn)

通過(guò)deepseek等人工智能,是非常容易自己實(shí)現(xiàn)一個(gè)Trie樹(shù),我們就只實(shí)現(xiàn)字符串替換的功能,其他的就不使用了;

Trie樹(shù),又叫字典樹(shù),前綴樹(shù)(Prefix Tree),單詞查找樹(shù),是一種多叉樹(shù)的結(jié)構(gòu).

wKgZO2fs3_-AbLcgAAFcXyyz9_Y318.png

結(jié)構(gòu)說(shuō)明: 表示根節(jié)點(diǎn)(空節(jié)點(diǎn))

每個(gè)節(jié)點(diǎn)表示一個(gè)字符

粉色節(jié)點(diǎn)表示單詞結(jié)束標(biāo)記(使用 CSS class 實(shí)現(xiàn))

路徑示例:

root → c → a → t 組成 "cat"

root → c → a → r 組成 "car"

root → d → o → g 組成 "dog"

public class TrieKeywordReplacer implements Replacer {

    private final Trie trie;

    @Override
    public String replaceKeywords(String text) {
        return trie.replaceKeywords(text, "");
    }

    public TrieKeywordReplacer(String keyWords) {
        Trie trie = new Trie();
        for (String s : keyWords.split(";")) {
            trie.insert(s);
        }
        this.trie = trie;
    }

    static class TrieNode {
        Map children;
        boolean isEndOfWord;

        public TrieNode() {
            children = new HashMap();
            isEndOfWord = false;
        }
    }

    static class Trie {
        private TrieNode root;

        public Trie() {
            root = new TrieNode();
        }

        private synchronized void insert(String word) {
            TrieNode node = root;
            for (char c : word.toCharArray()) {
                if (node.children.get(c) == null) {
                    node.children.put(c, new TrieNode());
                }
                node = node.children.get(c);
            }
            node.isEndOfWord = true;
        }

        public String replaceKeywords(String text, String replacement) {
            StringBuilder result = new StringBuilder();
            int i = 0;
            while (i < text.length()) {
                TrieNode node = root;
                int j = i;
                TrieNode endNode = null;
                int endIndex = -1;
                while (j < text.length() && node.children.get(text.charAt(j)) != null) {
                    node = node.children.get(text.charAt(j));
                    if (node.isEndOfWord) {
                        endNode = node;
                        endIndex = j;
                    }
                    j++;
                }
                if (endNode != null) {
                    result.append(replacement);
                    i = endIndex + 1;
                } else {
                    result.append(text.charAt(i));
                    i++;
                }
            }
            return result.toString();
        }
    }
}

4個(gè)實(shí)現(xiàn)類對(duì)象的大小對(duì)比

對(duì)象大小
StrReplacer 12560
PatternReplacer 21592
TrieKeywordReplacer 184944
AhoCorasickReplacer 253896

性能對(duì)比

說(shuō)明:待替換一組關(guān)鍵詞共 400個(gè);JDK1.8

StrReplacer PatternReplacer TrieKeywordReplacer AhoCorasickReplacer
單線程循環(huán)1w次,平均單次性能(ns) 21843ns 28846ns 532ns 727ns
名稱中只有1個(gè)待替換的關(guān)鍵詞,2個(gè)并發(fā)線程,循環(huán)1w次,平均單次性能(ns),機(jī)器 CPU 30%左右 23444ns 39984ns 680ns 1157ns
名稱中只有20待替換的關(guān)鍵詞,2個(gè)并發(fā)線程,循環(huán)1w次,平均單次性能(ns),機(jī)器 CPU 30%左右 252738ns 114740ns 33900ns 113764ns
名稱中只有無(wú)待替換的關(guān)鍵詞,2個(gè)并發(fā)線程,循環(huán)1w次,平均單次性能(ns),機(jī)器 CPU 30%左右 22248ns 9253ns 397ns 738ns

?

通過(guò)性能對(duì)比,自己實(shí)現(xiàn)的Trie樹(shù)的性能是最好的,因?yàn)橹蛔隽颂鎿Q的邏輯,沒(méi)有實(shí)現(xiàn)其他功能,其次是使用AhoCorasick算法,因?yàn)槭褂?AhoCorasick算法,實(shí)現(xiàn)字符串替換是最基本的功能,AhoCorasick算法,還能精準(zhǔn)的匹配到在什么地方,出現(xiàn)過(guò)多少次等信息,功能非常強(qiáng)大;

通過(guò)對(duì)比編譯好的正則性能確實(shí)是比使用原生String.replace;

public class ReplacerTest {

    @Test
    public void testTrieKeywordReplacer(){
        //String name = skuName;
        //String expected = v2;
        //String name = "三星Samsung Galaxy S25+ 超擬人AI助理 驍龍8至尊版 AI拍照 翻譯手機(jī) 游戲手機(jī) 12GB+256GB 冷川藍(lán)";
        //String expected = name;

        String name = keyWords;
        String expected = v1;
        int cnt = 2;
        Replacer replacer = new TrieKeywordReplacer(keyWords);
        check(replacer, name, expected);
        for (int i = 0; i < cnt; i++) {
            checkExec(replacer, name);
        }
    }

    @Test
    public void 替換所有關(guān)鍵字() throws InterruptedException {
        //String name = skuName;
        //String expected = v2;
        //String name = "三星Samsung Galaxy S25+ 超擬人AI助理 驍龍8至尊版 AI拍照 翻譯手機(jī) 游戲手機(jī) 12GB+256GB 冷川藍(lán)";
        //String expected = name;

        String name = keyWords;
        String expected = v1;

        int cnt = 2;
        System.out.println("替換:" + name);
        Replacer replacer = new StrReplacer(keyWords);
        check(replacer, name, expected);
        for (int i = 0; i < cnt; i++) {
            checkExec(replacer, name);
        }


        replacer = new PatternReplacer(keyWords);
        check(replacer, name, expected);
        for (int i = 0; i < cnt; i++) {
            checkExec(replacer, name);
        }

        replacer = new TrieKeywordReplacer(keyWords);
        check(replacer, name, expected);
        for (int i = 0; i < cnt; i++) {
            checkExec(replacer, name);
        }

        replacer = new AhoCorasickReplacer(keyWords);
        check(replacer, name, expected);
        for (int i = 0; i < cnt; i++) {
            checkExec(replacer, name);
        }



    }


    @Test
    public void 無(wú)關(guān)鍵字替換() throws InterruptedException {
        //String name = skuName;
        //String expected = v2;
        String name = "三星Samsung Galaxy S25+ 超擬人AI助理 驍龍8至尊版 AI拍照 翻譯手機(jī) 游戲手機(jī) 12GB+256GB 冷川藍(lán)";
        String expected = name;

        //String name = keyWords;
        //String expected = v1;

        int cnt = 1;
        System.out.println("替換:" + name);
        Replacer replacer = new StrReplacer(keyWords);
        check(replacer, name, expected);
        for (int i = 0; i < cnt; i++) {
            checkExec(replacer, name);
        }


        replacer = new PatternReplacer(keyWords);
        check(replacer, name, expected);
        for (int i = 0; i < cnt; i++) {
            checkExec(replacer, name);
        }

        replacer = new TrieKeywordReplacer(keyWords);
        check(replacer, name, expected);
        for (int i = 0; i < cnt; i++) {
            checkExec(replacer, name);
        }

        replacer = new AhoCorasickReplacer(keyWords);
        check(replacer, name, expected);
        for (int i = 0; i < cnt; i++) {
            checkExec(replacer, name);
        }



    }

    @Test
    public void 有1個(gè)關(guān)鍵字替換() throws InterruptedException {
        //String name = skuName;
        //String expected = v2;
        //String name = "三星Samsung Galaxy S25+ 超擬人AI助理 驍龍8至尊版 AI拍照 翻譯手機(jī) 游戲手機(jī) 12GB+256GB 冷川藍(lán)";
        //String expected = name;

        //String name = keyWords;
        //String expected = v1;

        String name = "HUAWEI Pura 70 Pro 國(guó)家補(bǔ)貼500元 羽砂黑 12GB+512GB 超高速風(fēng)馳閃拍 華為鴻蒙智能手機(jī)";
        String expected = "HUAWEI Pura 70 Pro 500元 羽砂黑 12GB+512GB 超高速風(fēng)馳閃拍 華為鴻蒙智能手機(jī)";

        int cnt = 1;
        System.out.println("替換:" + name);
        Replacer replacer = new StrReplacer(keyWords);
        check(replacer, name, expected);
        for (int i = 0; i < cnt; i++) {
            checkExec(replacer, name);
        }


        replacer = new PatternReplacer(keyWords);
        check(replacer, name, expected);
        for (int i = 0; i < cnt; i++) {
            checkExec(replacer, name);
        }

        replacer = new TrieKeywordReplacer(keyWords);
        check(replacer, name, expected);
        for (int i = 0; i < cnt; i++) {
            checkExec(replacer, name);
        }

        replacer = new AhoCorasickReplacer(keyWords);
        check(replacer, name, expected);
        for (int i = 0; i < cnt; i++) {
            checkExec(replacer, name);
        }



    }


    static void check(Replacer replacer, String name, String expected) {
        System.out.println(replacer.getClass().getName()+",對(duì)象大?。?+ObjectSizeCalculator.getObjectSize(replacer));
        String newTxt = replacer.replaceKeywords(name);
        //System.out.println(newTxt);
        Assert.assertEquals(replacer.getClass().getName() + ",對(duì)比不一致!", expected, newTxt);
    }


    void checkExec(Replacer replacer, String name) {
        String newTxt = replacer.replaceKeywords(name);
        int nThreads  = 2;
        ExecutorService executorService = Executors.newFixedThreadPool(nThreads);
        CountDownLatch downLatch = new CountDownLatch(nThreads);
        int i = 0;
        while (i++ < nThreads) {
            executorService.submit(new Runnable() {
                @Override
                public void run() {
                    int i = 0;
                    long ns = System.nanoTime();
                    while (i++ < 100000) {
                        replacer.replaceKeywords(name);
                    }
                    String name = replacer.getClass().getName();
                    downLatch.countDown();
                    System.out.println(StringUtils.substring(name, name.length() - 50, name.length()) + "ti=" + i + ", t耗時(shí):" + (System.nanoTime() - ns) / i + "ns");
                }
            });
        }
        executorService.shutdown();
        try {
            downLatch.await();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }

最后

1、使用現(xiàn)成的AhoCorasick算法進(jìn)行實(shí)現(xiàn),是性能與穩(wěn)定性最優(yōu)的選擇,非常強(qiáng)調(diào)性能,還是可以自己實(shí)現(xiàn)Trie樹(shù)來(lái)實(shí)現(xiàn);

2、在真實(shí)的使用過(guò)程中,因?yàn)榇蟛糠值纳唐访Q最多出現(xiàn)幾個(gè)關(guān)鍵詞,并且待替換的關(guān)鍵詞往往都是比較多的,可以將這么關(guān)鍵詞找出找出幾個(gè)有代表性能的詞,做前置判斷,商品名稱中是否存在;再進(jìn)行全量替換;

如待替換的關(guān)鍵詞有:政府補(bǔ)貼、國(guó)補(bǔ)、支持國(guó)補(bǔ); 那么我們并不是直接就循環(huán)這個(gè)待替換的關(guān)鍵詞組,而是找出這么關(guān)鍵詞中都有的關(guān)鍵字”補(bǔ)”先判斷商品名稱中是否存在“補(bǔ)”字后,再做處理; 這里的前置判斷,還可以使用布隆過(guò)濾器實(shí)現(xiàn);


public String replaceKeywords (String skuName){
    Replacer replacer = new AhoCorasickReplacer(keyWords);
    if(skuName.contains("補(bǔ)")){
        return  replacer.replaceKeywords(skuName);
    } else {
        return skuName;
    }
}

參考

- [1] Aho-Corasick 算法 AC自動(dòng)機(jī)實(shí)現(xiàn)?

- [2] Trie字典樹(shù)?

審核編輯 黃宇

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

    關(guān)注

    23

    文章

    4738

    瀏覽量

    96687
  • 字符串
    +關(guān)注

    關(guān)注

    1

    文章

    594

    瀏覽量

    22889
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    LM3466 多 LED 電流平衡器技術(shù)手冊(cè)

    到電源的數(shù)或每個(gè) LED 的正向電壓 字符串。 如果任何 LED 燈在運(yùn)行過(guò)程中打開(kāi),LM3466 會(huì)自動(dòng)平衡通過(guò)所有剩余活動(dòng) LED 燈的電源電流。 如 因此,即使一些 LED
    的頭像 發(fā)表于 08-29 14:27 ?594次閱讀
    LM3466 多<b class='flag-5'>串</b> LED 電流平衡器技術(shù)手冊(cè)

    labview如何生成一個(gè)帶字符串返回的dll

    labview如何生成一個(gè)dll,如下圖,要求一個(gè)輸入,類型是字符串,返回類型也是字符串
    發(fā)表于 08-28 23:20

    在Python中字符串逆序有幾種方式,代碼是什么

    對(duì)于一個(gè)給定的字符串,逆序輸出,這個(gè)任務(wù)對(duì)于python來(lái)說(shuō)是一種很簡(jiǎn)單的操作,畢竟強(qiáng)大的列表和字符串處理的一些列函數(shù)足以應(yīng)付這些問(wèn)題 了,今天總結(jié)了一下python中對(duì)于字符串的逆序輸出的幾種常用
    的頭像 發(fā)表于 08-28 14:44 ?408次閱讀

    harmony-utils之StrUtil,字符串工具類

    harmony-utils之StrUtil,字符串工具類 harmony-utils 簡(jiǎn)介與說(shuō)明 [harmony-utils] 一款功能豐富且極易上手的HarmonyOS工具庫(kù),借助眾多實(shí)用工具類
    的頭像 發(fā)表于 07-03 11:32 ?255次閱讀

    STM32C031C6使用的是UART2通訊,通過(guò)printf()函數(shù)發(fā)送字符串時(shí),漢字錯(cuò)碼怎么解決?

    使用的是UART2通訊,通過(guò)printf()函數(shù)發(fā)送字符串時(shí),漢字錯(cuò)碼(見(jiàn)下圖),應(yīng)該是KEIL哪里沒(méi)有設(shè)置好的問(wèn)題。 啟用了UART2的中斷接收,可以接收到串口調(diào)試助手的數(shù)據(jù),但是緩存區(qū)的指針沒(méi)有歸零,下次接收時(shí)緩存區(qū)中的內(nèi)容接續(xù)(如下圖所示),不知道用什么命令來(lái)清除緩存區(qū)(即讓指針歸零)。
    發(fā)表于 03-07 12:30

    請(qǐng)問(wèn)如何用Verilog實(shí)現(xiàn)將ascaii碼數(shù)值字符串轉(zhuǎn)換成定點(diǎn)數(shù)?

    我需要接收一個(gè)ascaii碼字符串,內(nèi)容是12位有效數(shù)字的數(shù)值,帶小數(shù)。我不知道怎么把小數(shù)部分轉(zhuǎn)換成定點(diǎn)數(shù)。
    發(fā)表于 01-23 21:57

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

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

    字符串在編程中的應(yīng)用實(shí)例

    字符串在編程中有著廣泛的應(yīng)用,它們被用于表示文本數(shù)據(jù)、處理用戶輸入、構(gòu)建動(dòng)態(tài)內(nèi)容等。以下是一些字符串在編程中的應(yīng)用實(shí)例: 1. 用戶輸入與輸出 用戶輸入 :程序通常需要從用戶那里獲取輸入,這些輸入通
    的頭像 發(fā)表于 01-07 15:33 ?937次閱讀

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

    在編程語(yǔ)言中,字符串字符數(shù)組是兩種基本的數(shù)據(jù)結(jié)構(gòu),它們都用于存儲(chǔ)和處理文本數(shù)據(jù)。盡管它們?cè)诠δ苌嫌幸欢ǖ闹丿B,但在內(nèi)部表示、操作方式和使用場(chǎng)景上存在顯著差異。 1. 內(nèi)部表示 字符串 字符串
    的頭像 發(fā)表于 01-07 15:29 ?1504次閱讀

    字符串反轉(zhuǎn)的實(shí)現(xiàn)方式

    在編程中,字符串反轉(zhuǎn)是一個(gè)基礎(chǔ)而重要的操作,它涉及到將一個(gè)字符串中的字符順序顛倒過(guò)來(lái)。這個(gè)操作在多種編程語(yǔ)言中都有不同的實(shí)現(xiàn)方式,本文將探討幾種常見(jiàn)的字符串反轉(zhuǎn)方法。 1. 遞歸方法
    的頭像 發(fā)表于 01-07 15:27 ?1075次閱讀

    字符串處理方法 字符串轉(zhuǎn)數(shù)字的實(shí)現(xiàn)

    在編程中,將字符串轉(zhuǎn)換為數(shù)字是一個(gè)常見(jiàn)的需求。不同的編程語(yǔ)言有不同的方法來(lái)實(shí)現(xiàn)這一功能。以下是一些常見(jiàn)編程語(yǔ)言中的字符串轉(zhuǎn)數(shù)字的實(shí)現(xiàn)方法: Python 在Python中,可以使用內(nèi)置的 int
    的頭像 發(fā)表于 01-07 15:26 ?1224次閱讀

    字符串處理:4G模組軟件指南精要!

    最近一直有朋友咨詢我關(guān)于4G模組的字符串處理,今天我便把相關(guān)指南展示給大家。
    的頭像 發(fā)表于 11-17 09:57 ?733次閱讀
    <b class='flag-5'>字符串</b>處理:4G模組軟件指南精要!

    用udl里的字符串信息在局域網(wǎng)內(nèi)其他電腦連接sql數(shù)據(jù)庫(kù)為什么為出現(xiàn)連接失敗拒絕訪問(wèn)?

    SQL數(shù)據(jù)庫(kù)遠(yuǎn)程連接已經(jīng)開(kāi)啟。我用udl里的字符串信息,連接輸入的服務(wù)器地址去連接數(shù)據(jù)庫(kù),用戶名和密碼都沒(méi)錯(cuò),但是在服務(wù)器的電腦可以連接成功,同局域網(wǎng)內(nèi)其他電腦就會(huì)一直報(bào)錯(cuò),拒絕訪問(wèn),直接用udl
    發(fā)表于 11-16 09:50

    base64字符串轉(zhuǎn)換為二進(jìn)制文件

    Base64是一種編碼方法,用于將二進(jìn)制數(shù)據(jù)轉(zhuǎn)換為ASCII字符串。這種編碼通常用于在不支持二進(jìn)制數(shù)據(jù)的系統(tǒng)中傳輸數(shù)據(jù),例如電子郵件或網(wǎng)頁(yè)。將Base64字符串轉(zhuǎn)換為二進(jìn)制文件的過(guò)程相對(duì)簡(jiǎn)單,但需要
    的頭像 發(fā)表于 11-10 10:55 ?3372次閱讀

    labview中浮點(diǎn)數(shù)與十六進(jìn)制字符串相互轉(zhuǎn)化

    與下位機(jī)數(shù)據(jù)交流及通訊時(shí),經(jīng)常有浮點(diǎn)數(shù)與十六進(jìn)制字符串相互轉(zhuǎn)化的需求,經(jīng)過(guò)兩天總結(jié),找到了最簡(jiǎn)潔的相互轉(zhuǎn)化的方法,萌新歡迎大佬指正,文件也附上。*附件:HEX字符串與浮點(diǎn)數(shù)轉(zhuǎn)換.rar
    發(fā)表于 10-21 19:51