【发布时间】:2019-02-20 13:44:52
【问题描述】:
在我尝试使用 nodejs 和 socket.io 创建一个 omegle 克隆以用于学习目的时,我偶然发现了一个我不太确定如何解决的问题。
客户的套接字 id 和他们的兴趣存储在一个对象数组中。 然后我使用 lodash 过滤掉其他有相似兴趣的客户。这就是我卡住的地方。如果没有具有相似兴趣的客户,则应继续搜索,直到找到。所以我决定使用带有回调的递归函数,在找到匹配项时触发回调,如果没有,则再次调用该函数。
然而,这导致我出现最大调用堆栈超出错误。 下面是函数
socketApi.funcy = function(socket_id, client_interests, callback){
console.log("i am searching");
search = _.filter(socketApi.availabe,{interests:client_interests});
_.remove({socketID:socket_id});
if(search.strlen>0){
callback();
} else {
socketApi.funcy(socket_id, client_interests, callback);
}
};
下面是整个事情的完整代码
var socket_io = require('socket.io');
var _ = require('lodash');
var io = socket_io(3001);
var socketApi = {};
socketApi.rooms = [];
socketApi.available = [];
socketApi.taken = [];
socketApi.io = io;
socketApi.funcy = function(socket_id, client_interests, callback){
console.log("i am searching");
search = _.filter(socketApi.availabe,{interests:client_interests});
_.remove({socketID:socket_id});
if(search.strlen>0){
callback();
} else {
socketApi.funcy(socket_id, client_interests, callback);
}
};
io.on('connection',function(socket){
console.log("User connected");
socket.on('goChat', function(client_interests){
socketApi.available.push({
socketID : socket.id,
interests : client_interests
});
socket.emit('searching');
socketApi.funcy(socket.id, client_interests, function(){
console.log("okay i found a match");
});
});
socket.on('msg',function(msg){
console.log("received msg");
room = rooms[socket.id];
io.to(room).emit('msgrec',msg);
});
});
module.exports = socketApi;
有人可以阐明执行此操作的正确方法吗? 提前致谢。
【问题讨论】:
标签: javascript node.js asynchronous recursion socket.io