我正在使用 Socket.io 创建一个 rochambo 游戏。玩家将他们的赌注添加到等待列表中, Node 在 mondogDB session 中检查玩家是否有足够的钱这样做,然后在将其发送给其他玩家之前创建赌注。
我的代码有效,但如果我要求非常快地创建多个投注, Node 没有时间在下一个投注到达之前更新 mongoDB 中的玩家余额,尽管我有等待名单。因此,玩家即使没有足够的钱也可以下注,我想避免这种情况。
我找不到防止这种情况发生的方法。当然有回调或递归函数,但我没能成功。
对不起我的英语不好,我是法国人:)
这是代码的简化版本:
socket.on('placerunpari', function (screenName, amount, sign) {
newBetWaitingList.push({
screenName: screenName,
amount: amount,
sign: sign
});
for (var k in newBetWaitingList) {
screenName = newBetWaitingList[k].screenName;
amount = newBetWaitingList[k].amount;
sign = newBetWaitingList[k].sign;
playerModel.findOne({
screenName: screenName
}).exec(function (err, player) {
if (player != null) {
if (checkAmounts(amount) && (sign == "scissors" || sign == "rock" || sign == "paper")) {
if (amount <= player.balance) {
//DB writing
var newBet = new betModel({
screenName: screenName,
amount: amount,
sign: sign
});
newBet.save(function (err, res) {
io.sockets.socket(connected[screenName]).emit('mybet', newBet.id, amount, sign);
socket.broadcast.emit('newbet', newBet.id, screenName, amount);
creatorUpdateBalance(screenName, -amount);
})
} else {
io.sockets.socket(connected[screenName]).emit('showalert', 'You don\'t have enough money for this bet', 'red');
}
} else {
console.log('Unauthorized access');
}
}
});
newBetWaitingList.shift();
}});
最佳答案
感谢您的回答和帮助,它有效:
function CreateBet(task, callback) {
screenName = newBetWaitingList[k].screenName;
amount = newBetWaitingList[k].amount;
sign = newBetWaitingList[k].sign;
playerModel.findOne({
screenName: screenName
}).exec(function (err, player) {
if (player != null) {
if (checkAmounts(amount) && (sign == "scissors" || sign == "rock" || sign == "paper")) {
if (amount <= player.balance) {
//DB writing
var newBet = new betModel({
screenName: screenName,
amount: amount,
sign: sign
});
newBet.save(function (err, res) {
io.sockets.socket(connected[screenName]).emit('mybet', newBet.id, amount, sign);
socket.broadcast.emit('newbet', newBet.id, screenName, amount);
creatorUpdateBalance(screenName, -amount, function () {
callback();
});
})
} else {
io.sockets.socket(connected[screenName]).emit('showalert', 'You don\'t have enough money for this bet', 'red');
callback();
}
} else {
console.log('Unauthorized access');
callback();
}
}
});
}
var newBetWaitingList = async.queue(CreateBet, 1);
socket.on('placerunpari', function (screenName, amount, sign) {
newBetWaitingList.push({
screenName: screenName,
amount: amount,
sign: sign
});
});
关于Javascript - Node.js - 防止函数的多次执行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22405546/
我在使用omniauth/openid时遇到了一些麻烦。在尝试进行身份验证时,我在日志中发现了这一点:OpenID::FetchingError:Errorfetchinghttps://www.google.com/accounts/o8/.well-known/host-meta?hd=profiles.google.com%2Fmy_username:undefinedmethod`io'fornil:NilClass重要的是undefinedmethodio'fornil:NilClass来自openid/fetchers.rb,在下面的代码片段中:moduleNetclass
我的代码目前看起来像这样numbers=[1,2,3,4,5]defpop_threepop=[]3.times{pop有没有办法在一行中完成pop_three方法中的内容?我基本上想做类似numbers.slice(0,3)的事情,但要删除切片中的数组项。嗯...嗯,我想我刚刚意识到我可以试试slice! 最佳答案 是numbers.pop(3)或者numbers.shift(3)如果你想要另一边。 关于ruby-多次弹出/移动ruby数组,我们在StackOverflow上找到一
我想在一个没有Sass引擎的类中使用Sass颜色函数。我已经在项目中使用了sassgem,所以我认为搭载会像以下一样简单:classRectangleincludeSass::Script::FunctionsdefcolorSass::Script::Color.new([0x82,0x39,0x06])enddefrender#hamlengineexecutedwithcontextofself#sothatwithintemlateicouldcall#%stop{offset:'0%',stop:{color:lighten(color)}}endend更新:参见上面的#re
我遵循了教程http://gettingstartedwithchef.com/,第1章。我的运行list是"run_list":["recipe[apt]","recipe[phpap]"]我的phpapRecipe默认Recipeinclude_recipe"apache2"include_recipe"build-essential"include_recipe"openssl"include_recipe"mysql::client"include_recipe"mysql::server"include_recipe"php"include_recipe"php::modul
我正在尝试用ruby中的gsub函数替换字符串中的某些单词,但有时效果很好,在某些情况下会出现此错误?这种格式有什么问题吗NoMethodError(undefinedmethod`gsub!'fornil:NilClass):模型.rbclassTest"replacethisID1",WAY=>"replacethisID2andID3",DELTA=>"replacethisID4"}end另一个模型.rbclassCheck 最佳答案 啊,我找到了!gsub!是一个非常奇怪的方法。首先,它替换了字符串,所以它实际上修改了
我有一些代码在几个不同的位置之一运行:作为具有调试输出的命令行工具,作为不接受任何输出的更大程序的一部分,以及在Rails环境中。有时我需要根据代码的位置对代码进行细微的更改,我意识到以下样式似乎可行:print"Testingnestedfunctionsdefined\n"CLI=trueifCLIdeftest_printprint"CommandLineVersion\n"endelsedeftest_printprint"ReleaseVersion\n"endendtest_print()这导致:TestingnestedfunctionsdefinedCommandLin
我在用Ruby执行简单任务时遇到了一件奇怪的事情。我只想用每个方法迭代字母表,但迭代在执行中先进行:alfawit=("a".."z")puts"That'sanalphabet:\n\n#{alfawit.each{|litera|putslitera}}"这段代码的结果是:(缩写)abc⋮xyzThat'sanalphabet:a..z知道为什么它会这样工作或者我做错了什么吗?提前致谢。 最佳答案 因为您的each调用被插入到在固定字符串之前执行的字符串文字中。此外,each返回一个Enumerable,实际上您甚至打印它。试试
如何检查Ruby文件是否是通过“require”或“load”导入的,而不是简单地从命令行执行的?例如:foo.rb的内容:puts"Hello"bar.rb的内容require'foo'输出:$./foo.rbHello$./bar.rbHello基本上,我想调用bar.rb以不执行puts调用。 最佳答案 将foo.rb改为:if__FILE__==$0puts"Hello"end检查__FILE__-当前ruby文件的名称-与$0-正在运行的脚本的名称。 关于ruby-检查是否
如何在Ruby中按名称传递函数?(我使用Ruby才几个小时,所以我还在想办法。)nums=[1,2,3,4]#Thisworks,butismoreverbosethanI'dlikenums.eachdo|i|putsiend#InJS,Icouldjustdosomethinglike:#nums.forEach(console.log)#InF#,itwouldbesomethinglike:#List.iternums(printf"%A")#InRuby,IwishIcoulddosomethinglike:nums.eachputs在Ruby中能不能做到类似的简洁?我可以只
//1.验证返回状态码是否是200pm.test("Statuscodeis200",function(){pm.response.to.have.status(200);});//2.验证返回body内是否含有某个值pm.test("Bodymatchesstring",function(){pm.expect(pm.response.text()).to.include("string_you_want_to_search");});//3.验证某个返回值是否是100pm.test("Yourtestname",function(){varjsonData=pm.response.json