# 原子操作
用于文件操作的Nette \ Utils \ SafeStram協議保證每個文件操作的原子性和隔離。
為什么它實際上好? 讓我們從一個簡單的例子開始,我們重復寫入相同的字符串到文件,然后讀取它:`
~~~
$s = str_repeat('Long String', 10000);
$counter = 1000;
while ($counter--) {
file_put_contents('soubor', $s); // write it
$readed = file_get_contents('soubor'); // read it
if ($s !== $readed) { // check it
echo 'Strings are different!';
}
}
~~~
看起來回聲的字符串是不同的! 命令不能被執行。 相反是真的。 嘗試在兩個瀏覽器中同時運行此腳本。 錯誤幾乎立即發生。
這是因為當在同一時間(即,在多個線程)重復執行時,代碼是不安全的。 這是互聯網上沒有什么不尋常的,在那里幾個人經常連接到一個網站在同一時間。 因此,確保您的應用程序可以一次處理多個線程,這是非常重要的 - 它是線程安全的,因為本機PHP函數不是。 否則,您可以預期數據丟失和奇怪的錯誤發生。
如何確保,像file_get_contets或fwrite的函數原子性地行為? SafeStream協議提供了一個安全的解決方案,所以我們可以通過標準的PHP函數原子操作文件。 加載Nette Framework時,協議自動可用。 之后,你只需要前綴的文件名nette.safe://:
~~~
$handle = fopen('nette.safe://test.txt', 'x'); // prefix the filename with nette.safe://
fwrite($handle, 'Nette Framework'); // for now, the data is written into a temporary file
fclose($handle); // and only now the file is renamed to test.txt
~~~
你當然可以使用所有熟悉的功能,如:
~~~
file_put_contents('nette.safe://test.txt', $content);
$ini = parse_ini_file('nette.safe://autoload.ini');
~~~
SafeStream保證:
原子性:文件作為一個整體寫或根本不寫。
隔離:沒有人可以開始讀取尚未完全寫入的文件。
如果您以“a”模式(附加)寫入現有文件,SafeStream將創建它的副本,只有在成功寫入后,它才會將其重命名為原始名稱。 因此,在此模式下寫入比在其他模式下更耗資源。
- Nette簡介
- 快速開始
- 入門
- 主頁
- 顯示文章詳細頁
- 文章評論
- 創建和編輯帖子
- 權限驗證
- 程序員指南
- MVC應用程序和控制器
- URL路由
- Tracy - PHP調試器
- 調試器擴展
- 增強PHP語言
- HTTP請求和響應
- 數據庫
- 數據庫:ActiveRow
- 數據庫和表
- Sessions
- 用戶授權和權限
- 配置
- 依賴注入
- 獲取依賴關系
- DI容器擴展
- 組件
- 字符串處理
- 數組處理
- HTML元素
- 使用URL
- 表單
- 驗證器
- 模板
- AJAX & Snippets
- 發送電子郵件
- 圖像操作
- 緩存
- 本土化
- Nette Tester - 單元測試
- 與Travis CI的持續集成
- 分頁
- 自動加載
- 文件搜索:Finder
- 原子操作