国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > .NET > 正文

asp.net中C++單例實現問題分析_.Net教程

2024-07-10 12:52:49
字體:
來源:轉載
供稿:網友

推薦:簡單理解Web Service三種實現方式
Web Service概念: 根據W3C的定義,Web服務(Web service)應當是一個軟件系統,用以支持網絡間不同機器的互動操作。網絡服務通常是許多應用程序接口(API)所組成的,它們通過網絡的遠程服務器端,執行客戶所提交服務的請求。簡單的來說就是服務器端向客戶端提供服務。 We

   方案一

  這是最簡單的版本,在單線程下(或者是C++0X下)是沒任何問題的,但在多線程下就不行了,因為static QMManager instance_;這句話不是線程安全的。

  在局部作用域下的靜態變量在編譯時,編譯器會創建一個附加變量標識靜態變量是否被初始化,會被編譯器變成像下面這樣(偽代碼):

  這里有競爭條件,兩個線程同時調用instance()時,一個線程運行到if語句進入后還沒設constructed值,此時切換到另一線程,constructed值還是false,同樣進入到if語句里初始化變量,兩個線程都執行了這個單例類的初始化,就不再是單例了。

  方案二

  一個解決方法是加鎖:

  但這樣每次調用instance()都要加鎖解鎖,代價略大。

  方案三

  那再改變一下,把內部靜態實例變成類的靜態成員,在外部初始化,也就是在include了文件,main函數執行前就初始化這個實例,就不會有線程重入問題了:

  這被稱為餓漢模式,程序一加載就初始化,不管有沒有調用到。

  看似沒問題,但還是有坑,在一個2B情況下會有問題:在這個單例類的構造函數里調用另一個單例類的方法可能會有問題。

  看例子:

  這里QMManager的構造函數調用了QMSqlite的instance函數,但此時QMSqlite::instance_可能還沒有初始化。

  這里的執行流程:程序開始后,在執行main前,執行到QMManager QMManager::instance_;這句代碼,初始化QMManager里的instance_靜態變量,調用到QMManager的構造函數,在構造函數里調用QMSqlite::instance(),取QMSqlite里的instance_靜態變量,但此時QMSqlite::instance_還沒初始化,問題就出現了。

  那這里會crash嗎,測試結果是不會,這應該跟編譯器有關,靜態數據區空間應該是先被分配了,在調用QMManager構造函數前,QMSqlite成員函數在內存里已經存在了,只是還未調到它的構造函數,所以輸出是這樣:

  QMManager constructor

  QMSqlite do_something

  QMSqlite constructor

  方案四

  那這個問題怎么解決呢,單例對象作為靜態局部變量有線程安全問題,作為類靜態全局變量在一開始初始化,有以上2B問題,那結合下上述兩種方式,可以解決這兩個問題。boost的實現方式是:單例對象作為靜態局部變量,但增加一個輔助類讓單例對象可以在一開始就初始化。如下:

  結合方案3的.cpp,這下可以看到正確的輸出和調用了:

  QMManager constructor

  QMSqlite constructor

  QMSqlite do_something

  來看看這里的執行流程:

  初始化QMManager類全局靜態變量create_object_

  ->調用object_creator的構造函數

  ->調用QMManager::instance()方法初始化單例

  ->執行QMManager的構造函數

  ->調用QMSqlite::instance()

  ->初始化局部靜態變量QMSqlite instance

  ->執行QMSqlite的構造函數,然后返回這個單例。

  跟方案三的區別在于QMManager調用QMSqlite單例時,方案3是取到全局靜態變量,此時這個變量未初始化,而方案四的單例是靜態局部變量,此時調用會初始化。

  跟最初方案一的區別是在main函數前就初始化了單例,不會有線程安全問題。

  最終boost

  上面為了說明清楚點去除了模版,實際使用是用模版,不用寫那么多重復代碼,這是boost庫的模板實現:

  其實Boost庫這樣的實現像打了幾個補丁,用了一些奇技淫巧,雖然確實繞過了坑實現了需求,但感覺挺不好的。

分享:Asp.net中Ajax與JQuery的ready函數沖突怎么辦
Asp.net Ajax和Asp.net結合得很完美,發現不夠用的時候,難免想到了Jquery。一般Jquery和Asp.net Ajax這兩樣東西結合使用也常見,如果處理好的話,并不會沖突。但最近發現Jquery的ready()函數在PostBack回來的時候,ready里執行的動作竟然無效了,第一印象:會不會Asp.

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 醴陵市| 增城市| 乌兰察布市| 通渭县| 东方市| 株洲市| 广丰县| 长治市| 石首市| 梁平县| 孟村| 永靖县| 延川县| 图片| 井研县| 荣昌县| 昌乐县| 迁安市| 南溪县| 舟山市| 漠河县| 福海县| 平潭县| 略阳县| 伽师县| 灵丘县| 鄂托克前旗| 西安市| 常山县| 大关县| 仁寿县| 湖北省| 青岛市| 昆山市| 朝阳区| 隆昌县| 车险| 黄浦区| 十堰市| 峡江县| 十堰市|