[問題] 請問能保證lib function 只能被執行一次?

作者: gn00618777 (非常念舊)   2022-06-09 23:54:57
是這樣的。我提供一個 library function,此 function 是 block 的
所以caller 要 fork 出來執行此 function。我想要做防呆,就是fork執行此
function後又再 fork 執行此 function 時會 return fail 的功能
目前我的作法是此function 內會有share memory,裡面有個 count
當近來此 function:
if(cout > 0)
return fail;
count++;
這樣後來fork 出來執行此 function 就會 return
但後來覺得怪怪的
有可能在初始時兩個 process會處在
if(count > 0)
return fail;
作者: Schottky (順風相送)   2022-06-09 23:59:00
不知道你用哪個作業系統,但既然有 critical section把整個 library func 設成 critical section 不就好了我的話可能會用mutex,semaphore,file lock這一類的東西連上述東西都沒有的話還有大絕招 open(O_CREAT|O_EXCL)
作者: SFGEX (SFGEX)   2022-06-10 00:11:00
std::call_once或是function內寫一個static lambda 保證執行一次
作者: sarafciel (Cattuz)   2022-06-10 01:08:00
你如果預設caller必然用fork/thread去處理block issue不如考慮提供把fork/thread也包進去處理的wrapper?
作者: CoNsTaR ((const *))   2022-06-10 01:19:00
只能被執行一次(會被用掉/佔有)的意思是他是資源而不是資料,可以參考看看 Rust 的 FnOnce,Idris2 的 Linear type system 的實作,或其他類似 quantitative type theory 的系統都是怎麼做的(就算在不同 threads 之間也能保證資源的 ownership)
作者: OnlyRD (里巷人)   2022-06-10 01:44:00
atomic test_* or blocking queue try_* 可以研究一下
作者: gn00618777 (非常念舊)   2022-06-10 06:52:00
抱歉,是Linux系統
作者: Lipraxde (Lipraxde)   2022-06-10 16:27:00
Fork 成不同 process?還有為什麼想避免 reentrant?
作者: saladim (殺拉頂)   2022-06-21 01:55:00
看不太懂問題的"表示法" 看起來像是這個function永遠只能有個一process執行他, 在任一時間點, A或B但不能A,B都執

Links booklink

Contact Us: admin [ a t ] ucptt.com