上一篇中介绍了webSocket最基本的使用方式和配置类的编写,因为是单层的hashmap,所以可以根据账号进行一对一的放松,但是在群发方面只能够发送给所有人,并不能精确的区分范围。所以这就需要加入房间号这一标识,用来区分群发消息发给谁。只需要在原hashmap上在套一层hashmap记录房间号即可
public static Map<String, ConcurrentHashMap<String, Session>> rooms = new ConcurrentHashMap();
这里使用了ConcurrentHashMap,首先我们需要知道hashmap是通过使用一个全局的锁来同步不同线程间的并发访问,因此会带来不可忽视的性能问题相比hashmap而言也就是说hashmap本身是线程不安全的而ConcurrentHashMap是J.U.C(java.util.concurrent包)的重要成员,它是HashMap的一个线程安全的、支持高效并发的版本。在默认理想状态下,ConcurrentHashMap可以支持16个线程执行并发写操作及任意数量线程的读操作。所以这里选用了ConcurrentHashMap。以免在多个用户同时加入房间或发送消息是出现问题
在这种结构下如果想拿到房间的用户信息需要先执行rooms.get(roomId)。发送消息之类的操作和之前相同,但是这里需要注意一点就是房间号的销毁,如果当前房间没有成员可以销毁房间。