Java: Multithreading & UDP Socket Programming

后端 未结 4 881
闹比i
闹比i 2021-02-10 18:42

I am new to multithreading & socket programming in Java. I would like to know what is the best way to implement 2 threads - one for receiving a socket and one for sending a

4条回答
  •  我寻月下人不归
    2021-02-10 19:04

    First thing is first: your classes should start with a capital letter per the Java Naming Conventions:

    Class names should be nouns, in mixed case with the first letter of each internal word capitalized. Try to keep your class names simple and descriptive. Use whole words-avoid acronyms and abbreviations (unless the abbreviation is much more widely used than the long form, such as URL or HTML).

    Second: Try to break down the code into coherent sections and organize them around some common feature that you're dealing with... perhaps around the functionality or the model you're programming.

    The (basic) model for the server is that the only thing it does is receive socket connections... the server relies on a handler to handle those connections and that's it. If you try to build that model it would look something like this:

    class Server{
        private final ServerSocket serverSocket;
        private final ExecutorService pool;
    
        public Server(int port, int poolSize) throws IOException {
          serverSocket = new ServerSocket(port);
          pool = Executors.newFixedThreadPool(poolSize);
        }
    
        public void serve() {
          try {
            while(true) {
              pool.execute(new Handler(serverSocket.accept()));
            }
          } catch (IOException ex) {
            pool.shutdown();
          }
        }
      }
    
      class Handler implements Runnable {
        private final Socket socket;
        Handler(Socket socket) { this.socket = socket; }
        public void run() {
          // receive the datagram packets
        }
     }
    

    Third: I would recommend that you look at some existing examples.

    • Multi-threaded Client/Server Applications:
      http://www.ase.md/~aursu/ClientServerThreads.html
    • Doug Lea:
      http://www.developer.com/java/ent/article.php/3645111/Java-5s-BlockingQueue.htm (thanks to John)
      http://gee.cs.oswego.edu/dl/cpj/index.html (still can't find the exact example, but it's there somewhere... if you feel brave look over his allcode.java file).
    • Concurrency in Practice examples:
      http://www.javaconcurrencyinpractice.com/listings.html
    • Java Concurrency Tutorials:
      http://java.sun.com/docs/books/tutorial/essential/concurrency/

    Updated per comments:
    OK Ravi, there are some big issues with your code and some minor issues with it:

    1. I assume that the Receive class is your client... you should pull that out as a separate program (with its own main class) and run your server and multiple clients at the same time. Spawning a new "client thread" from your server for every new UDP package you send is a disturbing idea (big issue).

    2. When you make your client application, you should make it run the receiving code in its own while loop (minor issue), e.g.:

      public class Client extends Thread
      {
          public Client(/*..*/)
          {
              // initialize your client
          }
      
          public void run()
          {
              while(true)
              {
                  // receive UDP packets
                  // process the UDP packets
              }
          }
      
          public static void main(String[] args) throws IOException
          {
              // start your client
              new Client().start();
          }
      }
      
    3. You should only need just one thread per client and one thread per server (you technically don't even a separate thread in there since main has its own thread), so you might not find the ExecutorService that useful.

    Otherwise your approach is correct... but I would still recommend that you check out some of examples.

提交回复
热议问题