<!-- MHonArc v2.4.4 -->
<!--X-Subject: Re: Threads, IO handling, and Event Queues -->
<!--X-From-R13: pbqreNvoz.arg -->
<!--X-Date: from tacitus.globecomm.net [207.51.48.7] by mx3.ibm.net id 857799878.89904-1 Sat Mar  8 05:44:38 1997 -->
<!--X-Message-Id: 199703080549.FAA71336#out1,ibm.net -->
<!--X-Content-Type: text/plain -->
<!--X-Reference: 199703080356.DAA128585#out1,ibm.net -->
<!--X-Head-End-->
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2//EN">
<html>
<head>
<title>MUD-Dev message, Re: Threads, IO handling, and Event Queues</title>
<!-- meta name="robots" content="noindex,nofollow" -->
<link rev="made" href="mailto:coder#ibm,net">
</head>
<body background="/backgrounds/paperback.gif" bgcolor="#ffffff"
      text="#000000" link="#0000FF" alink="#FF0000" vlink="#006000">
  <font size="+4" color="#804040">
    <strong><em>MUD-Dev<br>mailing list archive</em></strong>
  </font>
      
<br>
[ <a href="../">Other Periods</a>
 | <a href="../../">Other mailing lists</a>
 | <a href="/search.php3">Search</a>
 ]
<br clear=all><hr>
<!--X-Body-Begin-->
<!--X-User-Header-->
<!--X-User-Header-End-->
<!--X-TopPNI-->
Date: 
[ <a href="msg00074.html">Previous</a>
 | <a href="msg00076.html">Next</a>
 ]
    
Thread: 
[ <a href="msg00074.html">Previous</a>
 | <a href="msg00082.html">Next</a>
 ]
    
Index: 
[ <A HREF="author.html#00075">Author</A>
 | <A HREF="#00075">Date</A>
 | <A HREF="thread.html#00075">Thread</A>
 ]
<!--X-TopPNI-End-->
<!--X-MsgBody-->
<!--X-Subject-Header-Begin-->
<H1>Re: Threads, IO handling, and Event Queues</H1>
<HR>
<!--X-Subject-Header-End-->
<!--X-Head-of-Message-->
<UL>
<LI><em>To</em>: <A HREF="mailto:mud-dev#null,net">mud-dev#null,net</A></LI>
<LI><em>Subject</em>: Re: Threads, IO handling, and Event Queues</LI>
<LI><em>From</em>: <A HREF="mailto:coder#ibm,net">coder#ibm,net</A></LI>
<LI><em>Date</em>: Fri, 07 Mar 97 21:32:40 -0800</LI>
</UL>
<!--X-Head-of-Message-End-->
<!--X-Head-Body-Sep-Begin-->
<HR>
<!--X-Head-Body-Sep-End-->
<!--X-Body-of-Message-->
<PRE>
On 06/03/97 at 07:26 AM, cg#ami-cg,GraySage.Edmonton.AB.CA (Chris Gray)
said:
>First, I'll comment about the goblin-fight and flee example. I don't like
>computer games that ignore my commands. I think I mentioned this when
>Chris L suggested something like it. One of the reasons why people play
>computer games, I think, is because the player is in some ways in full
>control. That will be lost if not all commands are executed, or if things
>are not done in the way the player specified. I wouldn't be surprised if
>some user's reacted very strongly to such things.
This becomes especially iomportant when user commands can launch actions
which persist over time.  As I recall the original example was ala:
  > l
  You are on a narrow spit of land which seperates the lake from the sea.
  > dig canal joining lake and sea
  You begin digging a canal.
  ...much much later...
  You finish digging the canal.
Fairly obviously the user does not want to type commands for every shovel
of dirt heaved, and the above level of gross automation is fairly playable
if a mite boring.  The problem enters when:
  > l
  You are on a narrow spit of land which seperates the lake from the sea.
  > dig canal joining lake and sea
  You begin digging a canal.
  ...time passes...
  Bubba tells you, "I need you.  Come help me quickly!  I'm in Krak's dungeon."  
  > n
  You can't leave until you finish the canal.
Oh no.  That's stupid.  Similarly:
  > n,n,n,n,e,e,w,n,n,w,s,e,d,w
  ...three norths and two easts later...
  There is a vast pile of fabulous wealth here!
  ...w,n,n,w,s,e,d,w...
  There nothing here dumbo.  You already passed the treasure!
There should be a way to interrupt the ongoing process, cancelling all
subsequent commands.  
>As for multi-threading, I would advocate understanding why you want to
>use it, before you devote much time to it. A program with multiple
>threads will run slower on a single-CPU computer than the equivalent
>program without threads. If you truly are targetting speedups by running
>on multiple CPU's, then fine. If not, then reorganizing your server into
>threads had better produce some real improvements in maintainability,
>etc., in order to offset the loss of speed.
This is not entirely true.  A thread can block until a resource is freed. 
A single threaded server can not afford to block, and would thus have to
periodically poll the resource to attempt the waiting action.  Expensies
vary, but MT code can be significantly faster and lighter than ST.  (Note: 
This is often the exception however).
I should also re-iterate for the new clan here that I adopted an MT
approach not for any glaring technical reasons, but more for the same
reasons I've been doing the whole project for the last umpty years:: as a
proof of concept and a method of teaching myself new areas and techniques
that I'm interested in.
>Personally, I believe that moving in the direction of not only threads,
>but multiple co-operating servers is important. Multi-player games will,
>I think, only get bigger, so we will need extra power to run them. It
>isn't going to be easy - that's why there really aren't any good
>distributed MUD servers yet.
Agreed.
-- 
J C Lawrence                               Internet: claw#null,net
----------(*)                              Internet: coder#ibm,net
...Honourary Member of Clan McFud -- Teamer's Avenging Monolith...
</PRE>
<!--X-Body-of-Message-End-->
<!--X-MsgBody-End-->
<!--X-Follow-Ups-->
<HR>
<!--X-Follow-Ups-End-->
<!--X-References-->
<!--X-References-End-->
<!--X-BotPNI-->
<UL>
<LI>Prev by Date:
<STRONG><A HREF="msg00074.html">Re: Threads, IO handling, and Event Queues</A></STRONG>
</LI>
<LI>Next by Date:
<STRONG><A HREF="msg00076.html">Re: Just a bit of musing</A></STRONG>
</LI>
<LI>Prev by thread:
<STRONG><A HREF="msg00074.html">Re: Threads, IO handling, and Event Queues</A></STRONG>
</LI>
<LI>Next by thread:
<STRONG><A HREF="msg00082.html">Re: Threads, IO handling, and Event Queues</A></STRONG>
</LI>
<LI>Index(es):
<UL>
<LI><A HREF="index.html#00075"><STRONG>Date</STRONG></A></LI>
<LI><A HREF="thread.html#00075"><STRONG>Thread</STRONG></A></LI>
</UL>
</LI>
</UL>
<!--X-BotPNI-End-->
<!--X-User-Footer-->
<!--X-User-Footer-End-->
<ul><li>Thread context:
<BLOCKQUOTE><UL>
<LI><strong><A NAME="00065" HREF="msg00065.html">Threads, IO handling, and Event Queues</A></strong>, 
Nathan Yospe <a href="mailto:yospe#hawaii,edu">yospe#hawaii,edu</a>, Thu 06 Mar 1997, 10:10 GMT
<UL>
<li><Possible follow-up(s)><br>
<LI><strong><A NAME="00066" HREF="msg00066.html">Re: Threads, IO handling, and Event Queues</A></strong>, 
Chris Gray <a href="mailto:cg#ami-cg,GraySage.Edmonton.AB.CA">cg#ami-cg,GraySage.Edmonton.AB.CA</a>, Thu 06 Mar 1997, 23:49 GMT
</LI>
<LI><strong><A NAME="00067" HREF="msg00067.html">Re: Threads, IO handling, and Event Queues</A></strong>, 
coder <a href="mailto:coder#ibm,net">coder#ibm,net</a>, Sat 08 Mar 1997, 11:38 GMT
</LI>
<LI><strong><A NAME="00074" HREF="msg00074.html">Re: Threads, IO handling, and Event Queues</A></strong>, 
coder <a href="mailto:coder#ibm,net">coder#ibm,net</a>, Sat 08 Mar 1997, 11:54 GMT
</LI>
<LI><strong><A NAME="00075" HREF="msg00075.html">Re: Threads, IO handling, and Event Queues</A></strong>, 
coder <a href="mailto:coder#ibm,net">coder#ibm,net</a>, Sat 08 Mar 1997, 13:44 GMT
</LI>
<LI><strong><A NAME="00082" HREF="msg00082.html">Re: Threads, IO handling, and Event Queues</A></strong>, 
Carter T Shock <a href="mailto:ctso#umiacs,umd.edu">ctso#umiacs,umd.edu</a>, Mon 10 Mar 1997, 21:59 GMT
</LI>
<LI><strong><A NAME="00084" HREF="msg00084.html">Re: Threads, IO handling, and Event Queues</A></strong>, 
Nathan Yospe <a href="mailto:yospe#hawaii,edu">yospe#hawaii,edu</a>, Tue 11 Mar 1997, 03:09 GMT
</LI>
<LI><strong><A NAME="00113" HREF="msg00113.html">Re: Threads, IO handling, and Event Queues</A></strong>, 
claw <a href="mailto:claw#null,net">claw#null,net</a>, Sat 15 Mar 1997, 07:41 GMT
</LI>
</UL>
</LI>
<LI><strong><A NAME="00053" HREF="msg00053.html">ListMail dupes</A></strong>, 
coder <a href="mailto:coder#ibm,net">coder#ibm,net</a>, Wed 05 Mar 1997, 14:38 GMT
</UL></BLOCKQUOTE>
</ul>
<hr>
<center>
[ <a href="../">Other Periods</a>
 | <a href="../../">Other mailing lists</a>
 | <a href="/search.php3">Search</a>
 ]
</center>
<hr>
</body>
</html>