- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我用Erlang编写了一个代码,并使用了timer.sleep(),但是当我编写timer.sleep(100)时,它是不错的,并且可以正常工作,但是我需要更多的时间来停止线程以及增加时间并运行计时器。使用spawn调用的函数中的sleep(100),然后代码不起作用。
在代码中,第二个io不在控制台中打印,因此该线程在时间time:sleep(1000)中死了。
request_handler ( Name, Amount, Banks ) ->
io:format("~p ~p ~p ~n", [Name, Amount, Banks]),
timer:sleep(1000),
io:format("~p ~p ~p ~n", [Name, Amount, Banks]),
if Amount < 50 ->
Ask_amount = rand:uniform(Amount);
true ->
Ask_amount = rand:uniform(50)
end,
Bank = lists:nth(rand:uniform(length(Banks)), Banks),
Pid = whereis(Bank),
Pid ! {self(), Ask_amount},
receive
{accept, Ask_amount} ->
request_handler(Name, (Amount - Ask_amount), Banks);
{reject} ->
request_handler(Name, Amount, lists:filter(fun (Elem) -> not lists:member(Elem, [Bank]) end, Banks ))
end.
最佳答案
In the code the second io does not print in console, so the thread dead in the line time:sleep(1000).
handle_request()
的进程在 sleep 时死亡,即在第二个format语句显示任何输出之前,则应该在某处看到错误消息。
I have the following function running in a process:
go() ->
io:format("hello"),
timer:sleep(1000),
io:format("goodbye").I don't see the second output. Why is my process dying during the sleep?
request_handler()
进程休眠1秒:
-module(handlers).
-compile([export_all]).
request_handler ( Name, Amount, Banks ) ->
io:format("Format1: ~p ~p ~p ~n", [Name, Amount, Banks]),
timer:sleep(1000),
io:format("Format2: ~p ~p ~p ~n", [Name, Amount, Banks]),
% This is how you write an if statement when you want to assign
% the result to a variable:
AskAmount = if
Amount < 50 -> rand:uniform(Amount);
true -> rand:uniform(50)
end,
Bank = lists:nth(rand:uniform(length(Banks)), Banks),
Pid = whereis(Bank),
Pid ! {self(), AskAmount},
receive
{accept, AskAmount} ->
request_handler(Name, (Amount - AskAmount), Banks);
{reject} ->
request_handler(
Name,
Amount,
lists:filter(fun (Elem) -> not lists:member(Elem, [Bank]) end,
Banks
)
)
end.
Warning: variable 'Ask_amount' exported from 'if
-module(bank).
-compile(export_all).
init(Name) ->
register(Name, spawn(?MODULE, loop, [ok])).
loop(State) ->
receive
{From, Amount} ->
From ! {accept, Amount},
loop(State)
end.
create_banks(Names) ->
lists:foreach(
fun(Name) -> init(Name) end,
Names %=> [bank1, bank2, bank3]
).
-module(my).
-compile([export_all]).
go() ->
BankNames = [bank1, bank2, bank3],
bank:create_banks(BankNames),
handlers:request_handler("Hello", 500, BankNames).
~/erlang_programs$ erl
Erlang/OTP 20 [erts-9.3] [source] [64-bit] [smp:4:4] [ds:4:4:10] [async-threads:10] [hipe] [kernel-poll:false]
Eshell V9.3 (abort with ^G)
1> c(bank).
bank.erl:2: Warning: export_all flag enabled - all functions will be exported
{ok,bank}
2> c(handlers).
handlers.erl:2: Warning: export_all flag enabled - all functions will be exported
{ok,handlers}
3> c(my).
my.erl:2: Warning: export_all flag enabled - all functions will be exported
{ok,my}
4> my:go().
Format1: "Hello" 500 [bank1,bank2,bank3]
Format2: "Hello" 500 [bank1,bank2,bank3]
Format1: "Hello" 499 [bank1,bank2,bank3]
Format2: "Hello" 499 [bank1,bank2,bank3]
Format1: "Hello" 488 [bank1,bank2,bank3]
Format2: "Hello" 488 [bank1,bank2,bank3]
Format1: "Hello" 468 [bank1,bank2,bank3]
Format2: "Hello" 468 [bank1,bank2,bank3]
Format1: "Hello" 460 [bank1,bank2,bank3]
Format2: "Hello" 460 [bank1,bank2,bank3]
Format1: "Hello" 456 [bank1,bank2,bank3]
Format2: "Hello" 456 [bank1,bank2,bank3]
Format1: "Hello" 419 [bank1,bank2,bank3]
...
...
^C^C
I want to run function 'request_handler' more than one time concurrently. ...but when I run the request handler:
spawn(handlers, request_handler, [hello, 450, Banks])
the second io not working.
-module(my).
-compile([export_all]).
go() ->
BankNames = [bank1, bank2, bank3],
bank:create_banks(BankNames),
lists:foreach(
fun(N) ->
spawn(handlers, request_handler, [N, 500, BankNames])
end,
lists:seq(1, 5) %=> [1, 2, 3, 4, 5]
).
~/erlang_programs$ erl
Erlang/OTP 20 [erts-9.3] [source] [64-bit] [smp:4:4] [ds:4:4:10] [async-threads:10] [hipe] [kernel-poll:false]
Eshell V9.3 (abort with ^G)
1> c(bank).
bank.erl:2: Warning: export_all flag enabled - all functions will be exported
{ok,bank}
2> c(handlers).
handlers.erl:2: Warning: export_all flag enabled - all functions will be exported
{ok,handlers}
3> c(my).
my.erl:2: Warning: export_all flag enabled - all functions will be exported
{ok,my}
4> my:go().
process(<0.84.0>): Format1: 1 500 [bank1,bank2,bank3]
process(<0.85.0>): Format1: 2 500 [bank1,bank2,bank3]
process(<0.86.0>): Format1: 3 500 [bank1,bank2,bank3]
process(<0.87.0>): Format1: 4 500 [bank1,bank2,bank3]
process(<0.88.0>): Format1: 5 500 [bank1,bank2,bank3]
ok
process(<0.84.0>): Format2: 1 500 [bank1,bank2,bank3]
process(<0.85.0>): Format2: 2 500 [bank1,bank2,bank3]
process(<0.86.0>): Format2: 3 500 [bank1,bank2,bank3]
process(<0.87.0>): Format2: 4 500 [bank1,bank2,bank3]
process(<0.88.0>): Format2: 5 500 [bank1,bank2,bank3]
process(<0.84.0>): Format1: 1 467 [bank1,bank2,bank3]
process(<0.87.0>): Format1: 4 471 [bank1,bank2,bank3]
process(<0.85.0>): Format1: 2 465 [bank1,bank2,bank3]
process(<0.86.0>): Format1: 3 460 [bank1,bank2,bank3]
process(<0.88.0>): Format1: 5 453 [bank1,bank2,bank3]
process(<0.84.0>): Format2: 1 467 [bank1,bank2,bank3]
process(<0.87.0>): Format2: 4 471 [bank1,bank2,bank3]
process(<0.85.0>): Format2: 2 465 [bank1,bank2,bank3]
process(<0.86.0>): Format2: 3 460 [bank1,bank2,bank3]
process(<0.88.0>): Format2: 5 453 [bank1,bank2,bank3]
process(<0.84.0>): Format1: 1 422 [bank1,bank2,bank3]
process(<0.86.0>): Format1: 3 441 [bank1,bank2,bank3]
process(<0.87.0>): Format1: 4 461 [bank1,bank2,bank3]
process(<0.88.0>): Format1: 5 413 [bank1,bank2,bank3]
process(<0.85.0>): Format1: 2 442 [bank1,bank2,bank3]
process(<0.84.0>): Format2: 1 422 [bank1,bank2,bank3]
process(<0.86.0>): Format2: 3 441 [bank1,bank2,bank3]
process(<0.87.0>): Format2: 4 461 [bank1,bank2,bank3]
process(<0.88.0>): Format2: 5 413 [bank1,bank2,bank3]
process(<0.85.0>): Format2: 2 442 [bank1,bank2,bank3]
process(<0.84.0>): Format1: 1 405 [bank1,bank2,bank3]
process(<0.86.0>): Format1: 3 416 [bank1,bank2,bank3]
process(<0.87.0>): Format1: 4 439 [bank1,bank2,bank3]
process(<0.88.0>): Format1: 5 376 [bank1,bank2,bank3]
process(<0.85.0>): Format1: 2 419 [bank1,bank2,bank3]
process(<0.84.0>): Format2: 1 405 [bank1,bank2,bank3]
process(<0.86.0>): Format2: 3 416 [bank1,bank2,bank3]
process(<0.87.0>): Format2: 4 439 [bank1,bank2,bank3]
process(<0.88.0>): Format2: 5 376 [bank1,bank2,bank3]
process(<0.85.0>): Format2: 2 419 [bank1,bank2,bank3]
process(<0.84.0>): Format1: 1 397 [bank1,bank2,bank3]
process(<0.86.0>): Format1: 3 394 [bank1,bank2,bank3]
process(<0.85.0>): Format1: 2 389 [bank1,bank2,bank3]
process(<0.87.0>): Format1: 4 401 [bank1,bank2,bank3]
process(<0.88.0>): Format1: 5 340 [bank1,bank2,bank3]
process(<0.84.0>): Format2: 1 397 [bank1,bank2,bank3]
process(<0.86.0>): Format2: 3 394 [bank1,bank2,bank3]
process(<0.85.0>): Format2: 2 389 [bank1,bank2,bank3]
process(<0.87.0>): Format2: 4 401 [bank1,bank2,bank3]
process(<0.88.0>): Format2: 5 340 [bank1,bank2,bank3]
process(<0.84.0>): Format1: 1 367 [bank1,bank2,bank3]
process(<0.87.0>): Format1: 4 400 [bank1,bank2,bank3]
process(<0.86.0>): Format1: 3 355 [bank1,bank2,bank3]
process(<0.85.0>): Format1: 2 370 [bank1,bank2,bank3]
process(<0.88.0>): Format1: 5 313 [bank1,bank2,bank3]
process(<0.84.0>): Format2: 1 367 [bank1,bank2,bank3]
process(<0.87.0>): Format2: 4 400 [bank1,bank2,bank3]
process(<0.86.0>): Format2: 3 355 [bank1,bank2,bank3]
process(<0.85.0>): Format2: 2 370 [bank1,bank2,bank3]
process(<0.88.0>): Format2: 5 313 [bank1,bank2,bank3]
process(<0.84.0>): Format1: 1 337 [bank1,bank2,bank3]
process(<0.87.0>): Format1: 4 381 [bank1,bank2,bank3]
process(<0.88.0>): Format1: 5 299 [bank1,bank2,bank3]
process(<0.86.0>): Format1: 3 329 [bank1,bank2,bank3]
process(<0.85.0>): Format1: 2 367 [bank1,bank2,bank3]
^C^C
io:format()
语句都显示其输出。
ok
是
my:go()
的返回值,它返回
lists:foreach()
返回的所有内容,即
ok
。
关于multithreading - Erlang计时器:sleep(1000) cause dead in thread,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56571479/
我在 linux (Centos) 上使用 pthread 编程?我想让线程休眠一小段时间以等待某些事情。我正在尝试使用 sleep()、nanosleep() 或 usleep() 或其他可以做到这
此要求出现在我的 Android 应用程序中,但它通常适用于 Java。我的应用程序每隔几秒钟“做某事”。我已经按如下方式实现了这一点(只是相关的 fragment - 不是完整的代码): fragm
我正在使用 esp8266 构建 IR 到 WiFi 桥接器。基本上,我正在构建一个连接到红外 Remote 内的 esp8266 的红外接收器,以通过 wifi 将接收到的红外远程按键转发到服务器。
我想让 Toast 出现,然后让 sleep 运行。 如果我这样做,Toast 会在 sleep 后出现,但我希望反过来。有人有建议吗?这是我的代码 switch (checkedRadioButto
我在做一件简单的事情,打印一条错误消息,延迟执行 5 秒,然后调用另一个函数,这是代码 public void saveAndDisplay() throws InterruptedException
我的 Activity 上有一个按钮,当我单击它时,我希望按钮改变颜色,等待一段时间,然后再次改变颜色。 我尝试过以下两个版本的 sleep : 尝试1: public void buClick(Vi
我尝试过这个: for(int i =0; i1。创建ScheduledExecutorService public static ScheduledExecutorService createSch
我有一个 Winform,需要等待大约 3 - 4 小时。我无法关闭并以某种方式重新打开应用程序,因为它在等待时在后台做的事情很少。 为了实现等待 - 不给 UI 线程造成麻烦和其他原因 - 我有一个
我在网上看到了下面一段关于 Linux 线程的代码。但是当我运行它时,所有线程似乎都在 sleep ,而不仅仅是主线程。为什么?另外,如果没有 sleep(5),“线程创建成功”语句会运行 3 次而不
我有一个 php 脚本,我需要每 5 秒运行一次(运行,等待它完成,等待 5 秒,再次运行) 我有两种方法。要么在脚本中有一个带有 sleep 功能的无限循环,看起来像这样: while (1) {
我有一个图形用户界面,我想显示一些文本,然后稍等一下。 我的代码看起来像这样: //do something (add JTextArea, revalidate, repaint) try{
我想知道安卓手机的 sleep 模式和深度 sleep 模式有什么区别,手机进入休眠模式和深度 sleep 模式会有什么影响。 请提供详细的答案。 问候,皮克斯 最佳答案 深度 sleep 模式与休眠
我正在学习 C。在这个节目中我使用 sleep 功能来减慢倒计时。我的教科书没有指定我应该包含的库来使用 sleep 功能。所以我使用它时没有为它包含任何特殊的库并且它可以工作。但它在代码块中给了我这
我正在尝试模拟按键按下和按键 Action 。 例如:2638 毫秒。 SendMessage(hWnd, WM_KEYDOWN, keyCode, 0); Sleep(2638); SendMess
我在 while 循环中调用一个线程 hibernate 1 秒。当标志为真时,循环将运行(标志为真无限时间)。在循环线程内应该 hibernate 1 秒,唤醒并增加计数器,检查 IF 条件,在 F
有很多文件说“你应该避免使用带警报的 sleep ,因为许多系统使用警报来实现 sleep ”。实际上,我正在为这个问题而苦恼。 那么,当 sleep() 不能很好地处理警报时,是否有人可以帮助我“
我有两个带有图像的jlabel..我尝试在单击另一个标签时更改标签中的图像..(例如游戏)..我有一个问题..当我编写 Thread.sleep 时,图像没有改变..请参阅代码: public cla
我正在研究多线程,我有一个关于线程 sleep 方法的问题。当我在已经处于 sleep 线程(时间 t2)中执行 sleep()(时间 t1)方法时。总 sleep 时间为 t1+t2 或 t2(如果
如果我们不向 sleep( ) 函数传递任何参数,默认 sleep 时间是多少? #include int main() { int pid,dip,cpid; pid = fork(
当我转到 asyncio 页面时,第一个示例是一个 hello world 程序。当我在 python 3.73 上运行它时,我看不出与正常的有什么不同。 谁能告诉我区别并举一个重要的例子? In [
我是一名优秀的程序员,十分优秀!