其实,这样子的要求就能满足古屋的设想,那么不管如何去制作一款游戏,先把聊天能够功能设计出来。古屋根据原理,设计了一个exe作为了客户端,另一个exe作为了服务端,利用核心支持库里面的“客户”和“服务器”的两个组件就是实现了最原始的连接了。设置好端口,一般默认的都是“19730”,利用客户1.连接(“127.0.0.1”,19730)这个命令就能实现本机上的连接。然后就是设置通过客户端的客户1.发送信息以及服务端的服务器1.取回数据和服务器1.取回客户等相关命令拼接起来。
简单的通讯是不会难倒认真看过视频就古屋了,但是为了实现一边聊天一边玩游戏的梦想,那就要动点脑筋的。不过,一通百通,其实客户1.发送信息是通过点击某一按钮的即能发送,也没有限制发送的内容,那么,如果通过人为的方式去标注一些指令的行为,那就能够实现服务端对数据的处理。当发送信息的开头是以“001”开头的时候,就让服务端判断为聊天信息,只需要将信息反馈给所有在线的用户即可,而当发送信息的开头是“002”开头的时候,就让服务端判断为玩家的游戏行为,可能需要将数字后面的所有玩家信息进行处理,然后与数据库的内容进行比对,然后通过一系列的运算得出反馈的结果,在通过服务器1.发送数据将所需要返还的数据返回给玩家,让玩家继续进行下一步操作。通过对命令信息的判断,从而就实现了聊天和游戏的双重任务,看上去很美妙。
文字打起来的这个思路,看上不是很难,但是实际操作的时候,就复杂多了。那么多的处理信息,如何将信息记录怎是一个大问题。一开始,古屋想到的是常用的读写配置项的方法,不过有些数据是常用的,就好像是常量一般,通过读写配置项有点麻烦,古屋就继续寻找,花了一点心思,终于找到了易语言自带的数据库(edb数据库),这个是比较简单的,常用的也就是写和读等几个常用的数据库。人的思维不能固化,古屋的确蛮佩服一些人坚持不懈的毅力,记得在使用五滴的时候,有人为了一个日常任务,前前后后写了几十个配置项用于操作,当然,这也是五滴软件的局限性所致,要是五滴能够支持数据库,或许会好一些。但是,如果坚持不变,就不对了。当五滴更新到最新版本的时候,还有人坚持用着老版本,重复写着无数个配置,其精神可嘉,但是行为古屋认为不值得提倡。不能够因循守旧,要尝试着去用一些自己从来没有用到过的命令,可能通过一些命令,是能够取出网页源码中的中间文本,但是,也要去尝试着利用正则的方法去匹配看看。
一次浩大的网络聊天室的工程让古屋一下子成长了不少,也弥补了不少以前没有学到的知识。当他把游戏的软件放到某一个免费服务器上运行的时候,当一个叫做暮棠的曾经游戏里面朋友,登陆上了“游戏”,在聊天栏里面发出一声:“古屋,在吗?”的时候,古屋似乎看到了游戏重做的梦想曙光。
可惜,很快古屋就将完成的第一期游戏开发给搁置了。很多人或许会惋惜,但是现在考量起来,终止这种创作是正确的。因为,古屋的知识真的很单薄,如果当时当刻就沉浸在成绩的功劳簿上,他难以取得成功。这不是一款成熟的软件,只能作为一种代码进行分享。当古屋把游戏的一套源码发给五滴老大看的时候,老大就一语中的掐住了这东西的死穴:“你通过遍历数据库的方式,你的软件会不会很卡。”古屋第一次听过“遍历”两个词,真的觉得很新鲜,就有一种专业人士的味道。从字面上也能够理解遍历的含义,就是穷尽算法,常见的就是计次循环首那样一个都不放过。古屋后来想想觉得很有道理,通过计次循环首的方式去实现很多指令,现在十个客户都能够承受,当出现一百个甚至上千个的时候,估摸着那时候就会出现服务器卡死的现象了。
算了,放弃吧,古屋并没有灰心,就像是当年麦克阿瑟从菲律宾撤退时候的名句——“iik!”,这是他一次勇敢的尝试,梦想还在继续,等他的知识补充到位了,他还是会继续!