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

深入SQLite多線程的使用總結(jié)詳解

 更新時間:2013年05月16日 09:58:31   作者:  
本篇文章是對SQLite多線程的使用進行了詳細的分析介紹,需要的朋友參考下

SQLite支持3種線程模式:
  單線程:這種模式下,沒有進行互斥,多線程使用不安全。禁用所有的mutex鎖,并發(fā)使用時會出錯。當SQLite編譯時加了SQLITE_THREADSAFE=0參數(shù),或者在初始化SQLite前調(diào)用sqlite3_config(SQLITE_CONFIG_SINGLETHREAD)時啟用。

  多線程:這種模式下,只要一個數(shù)據(jù)庫連接不被多個線程同時使用就是安全的。源碼中是啟用bCoreMutex,禁用bFullMutex。實際上就是禁用數(shù)據(jù)庫連接和prepared statement(準備好的語句)上的鎖,因此不能在多個線程中并發(fā)使用同一個數(shù)據(jù)庫連接或prepared statement。當SQLite編譯時加了SQLITE_THREADSAFE=2參數(shù)時默認啟用。若SQLITE_THREADSAFE不為0,可以在初始化SQLite前,調(diào)用sqlite3_config(SQLITE_CONFIG_MULTITHREAD)啟用;或者在創(chuàng)建數(shù)據(jù)庫連接時,設置SQLITE_OPEN_NOMUTEX flag。

  串行:sqlite是線程安全的。啟用所有的鎖,包括bCoreMutex和bFullMutex 。因為數(shù)據(jù)庫連接和prepared statement都已加鎖,所以多線程使用這些對象時沒法并發(fā),也就變成串行了。當SQLite編譯時加了SQLITE_THREADSAFE =1參數(shù)時默認啟用。若SQLITE_THREADSAFE不為0,可以在初始化SQLite前,調(diào)用sqlite3_config(SQLITE_CONFIG_SERIALIZED)啟用;或者在創(chuàng)建數(shù)據(jù)庫連接時,設置SQLITE_OPEN_FULLMUTEX flag  。

    而這里所說的初始化是指調(diào)用sqlite3_initialize()函數(shù),這個函數(shù)在調(diào)用sqlite3_open()時會自動調(diào)用,且只有第一次調(diào)用是有效的.

   為了達到線程安全,SQLite在編譯時必須將 SQLITE_THREADSAFE 預處理宏置為1。在Windows和Linux上, 已編譯的好的二進制發(fā)行版中都是這樣設置的。如果不確定你所使用的庫是否是線程安全的,可以調(diào)用 sqlite3_threadsafe() 接口找出。調(diào)用sqlite3_threadsafe()可以獲得編譯期的SQLITE_THREADSAFE參數(shù) 。

   也就是說線程模式可以在編譯時(通過源碼編譯sqlite庫時)、啟動時(使用sqlite的應用程序初始化時)或者運行時(創(chuàng)建數(shù)據(jù)庫連接時)來指定。一般而言,運行時指定的模式將覆蓋啟動時的指定模式,啟動時指定的模式將覆蓋編譯時指定的模式。但是,單線程模式一旦被指定,將無法被覆蓋。默認的線程模式是串行模式。

編譯時選擇線程模式
    可以通過定義SQLITE_THREADSAFE宏來指定線程模式。如果沒有指定,默認為串行模式。定義宏SQLITE_THREADSAFE=1指定使用串行模式;=0使用單線程模式;=2使用多線程模式。

    sqlite3_threadsafe()函數(shù)的返回值可以確定編譯時指定的線程模式。如果指定了單線程模式,函數(shù)返回false。如果指定了串行或者多線程模式,函數(shù)返回true。由于sqlite3_threadsafe()函數(shù)要早于多線程模式以及啟動時和運行時的模式選擇,所以它既不能區(qū)別多線程模式和串行模式也不能區(qū)別啟動時和運行時的模式。

    最后一句可通過sqlite3_threadsafe函數(shù)的實現(xiàn)來理解SQLITE_API int sqlite3_threadsafe(void){ return SQLITE_THREADSAFE; }如果編譯時指定了單線程模式,那么臨界互斥邏輯在構(gòu)造時就被省略,因此也就無法在啟動時或運行時指定串行模式或多線程模式。

啟動時選擇線程模式
    假如在編譯時沒有指定單線程模式,就可以在應用程序初始化時使用sqlite3_config()函數(shù)修改線程模式。參數(shù)SQLITE_CONFIG_SINGLETHREAD可指定為
單線程模式,SQLITE_CONFIG_MULTITHREAD指定為多線程模式,SQLITE_CONFIG_SERIALIZED指定為串行模式。

運行時選擇線程模式
    如果沒有在編譯時和啟動時指定為單線程模式,那么每個數(shù)據(jù)庫連接在創(chuàng)建時可單獨的被指定為多線程模式或者串行模式,但是不能指定為單線程模式。如果在編譯時或啟動時指定為單線程模式,就無法在創(chuàng)建連接時指定多線程或者串行模式。

    創(chuàng)建連接時用sqlite3_open_v2()函數(shù)的第三個參數(shù)來指定線程模式。SQLITE_OPEN_NOMUTEX標識創(chuàng)建多線程模式的連接;SQLITE_OPEN_FULLMUTEX標識創(chuàng)建串行模式的連接。如果沒有指定標識,或者使用sqlite3_open()或sqlite3_open16()函數(shù)來創(chuàng)建數(shù)據(jù)庫連接,那么在編譯時或啟動時指定的線程模式將作為默認的線程模式使用。

相關文章

  • MyBatis中的SQL映射文件配置結(jié)果映射的操作指南

    MyBatis中的SQL映射文件配置結(jié)果映射的操作指南

    MyBatis?是一款優(yōu)秀的?ORM?框架,它提供了多種配置方式來定義?SQL?語句以及結(jié)果映射規(guī)則,本文將介紹?MyBatis?中的?SQL?映射文件如何配置結(jié)果映射,包括常規(guī)類型、集合類型等多種情況,需要的朋友可以參考下
    2023-07-07
  • springMVC如何將controller中Model數(shù)據(jù)傳遞到jsp頁面

    springMVC如何將controller中Model數(shù)據(jù)傳遞到jsp頁面

    本篇文章主要介紹了springMVC如何將controller中Model數(shù)據(jù)傳遞到jsp頁面,具有一定的參考價值,有興趣的可以了解一下
    2017-07-07
  • 細談java同步之JMM(Java Memory Model)

    細談java同步之JMM(Java Memory Model)

    Java內(nèi)存模型是在硬件內(nèi)存模型上的更高層的抽象,它屏蔽了各種硬件和操作系統(tǒng)訪問的差異性,保證了Java程序在各種平臺下對內(nèi)存的訪問都能達到一致的效果。下面我們來一起學習下JMM
    2019-05-05
  • Java每7天日志自動清理的項目實踐

    Java每7天日志自動清理的項目實踐

    在實際項目中由于服務器內(nèi)存有限,人工清理常會忘記,本文主要介紹了Java每7天日志自動清理的項目實踐,具有一定的參考價值,感興趣的可以了解一下
    2024-01-01
  • Spring?Boot中@Autowired注入為空的原因以及解決方法

    Spring?Boot中@Autowired注入為空的原因以及解決方法

    最近在開發(fā)中遇到了使用@Autowired注解自動裝配時會報空指針,發(fā)現(xiàn)對象并沒有裝配進來,下面這篇文章主要給大家介紹了關于Spring?Boot中@Autowired注入為空的原因以及解決方法,需要的朋友可以參考下
    2024-01-01
  • java實現(xiàn)單詞搜索迷宮游戲

    java實現(xiàn)單詞搜索迷宮游戲

    這篇文章主要介紹了java實現(xiàn)單詞搜索迷宮游戲,實例分析了迷宮游戲的實現(xiàn)技巧,需要的朋友可以參考下
    2015-05-05
  • 淺談Java中的hashcode方法(推薦)

    淺談Java中的hashcode方法(推薦)

    本篇文章主要介紹了Java中的hashcode方法,詳細的介紹了hashCode方法的作用,具有一定的參考價值,有需要的可以了解一下。
    2016-12-12
  • SpringBoot集成kaptcha驗證碼

    SpringBoot集成kaptcha驗證碼

    這篇文章主要為大家詳細介紹了SpringBoot集成kaptcha驗證碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • mybatis-plus批量更新updateBatchById問題

    mybatis-plus批量更新updateBatchById問題

    這篇文章主要介紹了mybatis-plus批量更新updateBatchById問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • Mybatis中返回Map的實現(xiàn)

    Mybatis中返回Map的實現(xiàn)

    這篇文章主要介紹了Mybatis中返回Map的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-03-03

最新評論