浏览 1302 次
锁定老帖子 主题:小型CHATROOM分析1
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2008-02-29
Chat程序思路分析: ■ 服务器端的程序流程:启动服务器,等待客户端的进入,客户端连接以后启动独立的线程,处理客户端的线程(发送欢迎文字要求客户输入用户名,给所有用户通知告诉所有人有用户进来,如果客户机发送一条消息 则把它发给所有的用户,还可以发送给指定的客户)。 ■ 编写三个类:ChatServer类,负责启动一个ServerSocket,使进入Socket的对象创建一个ProcessClient的对象,ProcessClient类实现了Runnable接口,它独立运行处理某一个客户端,创建成功后,把自己放入UserManager队列中,当要发送消息的时候,把消息发送给其他的客户端,并且在退出的时候,把自己从队列中删除。UserManager类是一个单实例形式的工具类,它提供给ProcessClient一些用户管理用户的方法,例如,加入用户,删除用户,广播消息等,由于会有多个用户线程处理其中的方法,所以其中的方法大多声明为synchronized. ■程序实现(错误和技巧) 1:首先创建工具类UserManager类:一个单实例类,里面的方法都声明为public static synchronized.接下来思考 需要对客户端传入的Socket转杯哪些管理的方法。取得一个线程对象,添加用户,删除用户,统计在线用户,给所有人发送消息,给指定的人发送消息,实例化一个用户线程的队列private static void java.util.Map<String,ProcessClient> clientMap=new java.util.HashMap; ●取得一个线程对象的方法: Public static synchronized ProcessClient getUserThread(String name) { //返回一个客户端 Return clientMap.get(name); } ●添加一个用户的方法: Public static synchronized ProcessClient addUserThread(String name.ProcessClient client) { Return clientMap.put(name,Client); } ●删除一个用户的方法: Public static synchronized ProcessClient deleteThread(String key) { Return clientMap.remove(key); } ●统计在线用户的方法: Public static synchronized int getOnlineCount() { Return clientMap.size(); } ●发信息给所有人的方法:参数srcName代表发送的人,msgContent 代表发送的消息内容 Public static synchronized sendToAllUser(String srcName,String msgContent) { //向客户端队列的一个遍历发送 msgContent= srcName+”说”+ msgContent+”\r\n”; //set是一个集合 java.util.Set<String > set= clientMap.keySet(); //遍历这个集合 java.util.Iterator key IT= set.iterator(); while(keyIT.hasNext()) { String keysUser= keyIT.next(); ProcessClient pc= clientMap.get(keysUser); //取出ProcessClient中的一个对象,然后向其他用户发送消息 Pc.sendToClient (srcName,msgContent); } } 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |