[问题] 请问能保证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