欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++?JSON庫?nlohmann::basic_json::accept的用法解析

 更新時(shí)間:2023年06月19日 14:41:54   作者:泡沫o0  
nlohmann::basic_json::accept 是 Nlohmann JSON 庫中的一個(gè)方法,它用于檢查一個(gè)字符串是否可以解析為有效的 JSON,這篇文章主要介紹了C++?JSON庫nlohmann::basic_json::accept的用法,需要的朋友可以參考下

簡介

nlohmann::basic_json::accept 是 Nlohmann JSON 庫中的一個(gè)方法,它用于檢查一個(gè)字符串是否可以解析為有效的 JSON。

方法的簽名如下:

bool accept(const string_t& input);

其中 input 是要檢查的字符串。

如果字符串可以解析為有效的 JSON,那么此方法會(huì)返回 true,否則返回 false

以下是一個(gè)使用示例:

#include <nlohmann/json.hpp>
using json = nlohmann::json;
int main() {
    std::string jsonString = R"({"key": "value"})";
    std::string notJsonString = R"(Not a json string)";
    bool jsonStringIsValid = json::accept(jsonString);
    bool notJsonStringIsValid = json::accept(notJsonString);
    std::cout << "jsonStringIsValid: " << jsonStringIsValid << '\n';
    std::cout << "notJsonStringIsValid: " << notJsonStringIsValid << '\n';
    return 0;
}

在這個(gè)示例中,jsonStringIsValid 會(huì)被設(shè)置為 true,因?yàn)?jsonString 是一個(gè)有效的 JSON 字符串,而 notJsonStringIsValid 會(huì)被設(shè)置為 false,因?yàn)?notJsonString 不是一個(gè)有效的 JSON 字符串。

nlohmann::basic_json::accept 官網(wǎng)介紹

// (1)
template<typename InputType>
static bool accept(InputType&& i, const bool ignore_comments = false);
// (2)
template<typename IteratorType>
static bool accept(IteratorType first, IteratorType last, const bool ignore_comments = false);

檢查輸入是否為有效的 JSON。

  • 從兼容的輸入中讀取。
  • 從一對(duì)字符迭代器中讀取。

迭代器的 value_type 必須是大小為 1、2 或 4 字節(jié)的整型,分別被解釋為 UTF-8、UTF-16 和 UTF-32。

與 parse 函數(shù)不同,此函數(shù)在遇到無效的 JSON 輸入(即,解析錯(cuò)誤)時(shí)既不拋出異常,也不創(chuàng)建診斷信息。

模板參數(shù)

InputType

兼容的輸入,例如:

  • 一個(gè) std::istream 對(duì)象
  • 一個(gè) FILE 指針(不能為 null)
  • 一個(gè) C 風(fēng)格的字符數(shù)組
  • 一個(gè)指向單字節(jié)字符的空終止字符串的指針
  • 一個(gè) std::string
  • 一個(gè)對(duì)象 obj,對(duì)于該對(duì)象,begin(obj) 和 end(obj) 產(chǎn)生一對(duì)有效的迭代器。

IteratorType

兼容的迭代器類型,例如:

  • 一對(duì) std::string::iterator 或 std::vector<uint8_t>::iterator
  • 一對(duì)指針,如 ptr 和 ptr + len

參數(shù)

  • i (in): 要解析的輸入。
  • ignore_comments (in): 是否應(yīng)忽略注釋并將其視為空格(true)或產(chǎn)生解析錯(cuò)誤(false);(可選,默認(rèn)為 false)
  • first (in): 字符范圍的開始迭代器
  • last (in): 字符范圍的結(jié)束迭代器

返回值

輸入是否為有效的 JSON。

異常安全性

強(qiáng)保證:如果拋出異常,JSON 值不會(huì)有任何改變。

復(fù)雜性

輸入長度線性。解析器是一個(gè)預(yù)測性的 LL(1) 解析器。

注釋

(1) UTF-8 字節(jié)順序標(biāo)記會(huì)被靜默忽略。

運(yùn)行時(shí)斷言:通過運(yùn)行時(shí)斷言來執(zhí)行傳遞的 FILE 指針不能為 null 的前提條件。

示例

#include <iostream>
#include <iomanip>
#include <nlohmann/json.hpp>
using json = nlohmann::json;
int main()
{
    // a valid JSON text
    auto valid_text = R"(
    {
        "numbers": [1, 2, 3]
    }
    )";
    // an invalid JSON text
    auto invalid_text = R"(
    {
        "strings": ["extra", "comma", ]
    }
    )";
    std::cout << std::boolalpha
              << json::accept(valid_text) << ' '
              << json::accept(invalid_text) << '\n';
}

另請(qǐng)參閱

  • parse - 從兼容的輸入反序列化
  • operator>> - 從流反序列化

版本歷史

  • 在版本 3.0.0 中添加。
  • 通過 ignore_comments 忽略注釋在版本 3.9.0 中添加。

棄用

重載 (2) 替換了將一對(duì)迭代器作為其第一個(gè)參數(shù)的 accept 調(diào)用,該調(diào)用在版本 3.8.0 中已被棄用。這個(gè)重載將在版本 4.0.0 中被移除。請(qǐng)將所有像 accept({ptr, ptr+len}, …); 的調(diào)用替換為accept(ptr, ptr+len, …);

到此這篇關(guān)于C++ JSON庫 nlohmann::basic_json::accept的用法的文章就介紹到這了,更多相關(guān)C++  nlohmann::basic_json::accept內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++鏈表類的封裝詳情介紹

    C++鏈表類的封裝詳情介紹

    這篇文章主要介紹了C++鏈表類的封裝,文章基于C++的相關(guān)資料展開主題的詳細(xì)內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-04-04
  • C++ 標(biāo)準(zhǔn)模板類詳解

    C++ 標(biāo)準(zhǔn)模板類詳解

    今天小編就為大家分享一篇關(guān)于C++標(biāo)準(zhǔn)模板類的介紹與使用講解,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2021-09-09
  • c++輸出斐波那契數(shù)列示例分享

    c++輸出斐波那契數(shù)列示例分享

    這篇文章主要介紹了c++輸出斐波那契數(shù)列示例,需要的朋友可以參考下
    2014-03-03
  • C語言柔性數(shù)組的實(shí)現(xiàn)示例

    C語言柔性數(shù)組的實(shí)現(xiàn)示例

    柔性數(shù)組既數(shù)組大小待定的數(shù)組, C語言中結(jié)構(gòu)體的最后一個(gè)元素可以是大小未知的數(shù)組,本文就來介紹一下柔性數(shù)組的用法,感興趣的可以了解一下
    2024-03-03
  • C++?正則表達(dá)式的應(yīng)用詳解

    C++?正則表達(dá)式的應(yīng)用詳解

    正則表達(dá)式(regular?expression)描述了一種字符串匹配的模式(pattern),可以用來檢查一個(gè)串是否含有某種子串、將匹配的子串替換或者從某個(gè)串中取出符合某個(gè)條件的子串等
    2021-11-11
  • Qt物聯(lián)網(wǎng)管理平臺(tái)之實(shí)現(xiàn)告警短信轉(zhuǎn)發(fā)

    Qt物聯(lián)網(wǎng)管理平臺(tái)之實(shí)現(xiàn)告警短信轉(zhuǎn)發(fā)

    系統(tǒng)在運(yùn)行過程中,會(huì)實(shí)時(shí)采集設(shè)備的數(shù)據(jù),當(dāng)采集到的數(shù)據(jù)發(fā)生報(bào)警后,可以將報(bào)警信息以短信的形式發(fā)送給指定的管理員。本文將利用Qt實(shí)現(xiàn)告警短信轉(zhuǎn)發(fā),感興趣的可以嘗試一下
    2022-07-07
  • C++實(shí)現(xiàn)俄羅斯方塊(linux版本)

    C++實(shí)現(xiàn)俄羅斯方塊(linux版本)

    這篇文章主要為大家詳細(xì)介紹了linux版本C++實(shí)現(xiàn)俄羅斯方塊,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-07-07
  • C語言數(shù)據(jù)結(jié)構(gòu)之棧簡單操作

    C語言數(shù)據(jù)結(jié)構(gòu)之棧簡單操作

    這篇文章主要介紹了C語言數(shù)據(jù)結(jié)構(gòu)之棧簡單操作的相關(guān)資料,需要的朋友可以參考下
    2017-06-06
  • C++ xxx_cast實(shí)現(xiàn)轉(zhuǎn)換代碼實(shí)例解析

    C++ xxx_cast實(shí)現(xiàn)轉(zhuǎn)換代碼實(shí)例解析

    這篇文章主要介紹了C++xxx_cast轉(zhuǎn)換代碼實(shí)例解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-07-07
  • C++ namespace相關(guān)語法實(shí)例分析

    C++ namespace相關(guān)語法實(shí)例分析

    這篇文章主要介紹了C++ namespace相關(guān)語法實(shí)例分析,對(duì)C++初學(xué)者有很好的參考借鑒價(jià)值,需要的朋友可以參考下
    2014-08-08

最新評(píng)論