Solved

How do I know when data had been read from a port and it can be closed

Posted on 2012-04-05
8
288 Views
Last Modified: 2012-04-09
I am using this snippet of Java code to send data to a port. If I execute the two close commands the receiver reading from the port throws a bind error: "Unrecognized Windows Sockets error: 0: JVM_Bind"

If I never execute the two close commands, the reader gets the data just fine.

I assume I must close the PrintWriter and echoSocket eventually...but how do I know when the receiver has read all the data so I can close?

Java code:

Socket echoSocket = new Socket(servername, Tx.getPortNumber());
PrintWriter out = new PrintWriter(echoSocket.getOutputStream(), true);
out.println(SendMessage);
out.close();
echoSocket.close();
0
Comment
Question by:cschene
  • 4
  • 4
8 Comments
 
LVL 86

Expert Comment

by:CEHJ
ID: 37814489
the receiver reading from the port throws a bind error: "Unrecognized Windows Sockets error: 0: JVM_Bind"

Can you please post the full stack trace?

Generally speaking, when you have this kind of thing happening (although the error message seems slightly odd in this case), the fault is in the protocol. It sounds like you have not arranged the protocol in an orderly way,such that the receiver is 'surprised' that the sender has closed the socket. If you can't rearrange the protocol, you will be forced to handle the exception at the receiver as 'unexceptional'
0
 

Author Comment

by:cschene
ID: 37814512
"Can you please post the full stack trace?"

How do I do that? I am processing the exception as follows:


catch(Exception e) {
                  x1.stopTimer();
                  x1.setPortData(e.getMessage() + " on port " + x1.getPortNumber());
                  System.err.println(e.getMessage());
                  }
0
 
LVL 86

Accepted Solution

by:
CEHJ earned 500 total points
ID: 37814519
Change

System.err.println(e.getMessage());

Open in new window


to

e.printStackTrace();

Open in new window


and post the output
0
Gigs: Get Your Project Delivered by an Expert

Select from freelancers specializing in everything from database administration to programming, who have proven themselves as experts in their field. Hire the best, collaborate easily, pay securely and get projects done right.

 

Author Comment

by:cschene
ID: 37815758
I figured out what my problem was...it was the parsing of the int...which I believe you answered as well.

What I am trying to do here is test a group of ports by sending a message to a port on a server (2112) and having the server send that message back to the client on the port that is specified in the message and repeat this until the client processes all ports and either verifies them as working or not working. We need this test because we have to keep certain ports open for our software to function.

The approach I am taking is (1) server waits on the Rx port (2112) for a message, (2) Server reads the message  and sends that exact message back to the client and then (4) the client processes the next port and so on until done.

This is experimental code:  I am just trying to figure out the proper approach and then I will throw away and re-write once I understand the design required.

if I run with the following commandline, the code will do a loopback test where it sends and receives on the same port. This works.

java CmServerPortTester -loopbacktest  -txport 2112 -rxport 2112

if I want to run a test of ports 2112, 500, 1024 I run two copies of the software. Note, server is defaulting to localhost...so I am looping on the same PC for testing.

server: java CmServerPortTester -server  -txport 2112 -rxport 2112
client: java CmServerPortTester -client  -txport 2112 -rxport 5000 -rxport 1024

So, it exchanges the first set of messages and verified one port, but the server side gets hung up after that.
CmServerPortTester.java
0
 
LVL 86

Expert Comment

by:CEHJ
ID: 37817249
but the server side gets hung up after that.

Where? At what line?
0
 

Author Comment

by:cschene
ID: 37817733
It is throwing when it hits this line


      Socket echoSocket = new Socket(servername, i);

In this Method: static void processServerPortTest(testPort x) {

I am not getting much detail on the exception. All I see is this: (how do I get more detail?)

Exception in thread "main" java.lang.NullPointerException
        at CmServerPortTester.processServerPortTest(CmServerPortTester.java:265)
        at CmServerPortTester.main(CmServerPortTester.java:66)
0
 
LVL 86

Expert Comment

by:CEHJ
ID: 37817822
It is throwing when it hits this line

Be careful - 'throwing' != 'hung'

 at CmServerPortTester.processServerPortTest(CmServerPortTester.java:265)

Open in new window


What line does that correspond to in the file you attached? (It's not the same)
0
 

Author Comment

by:cschene
ID: 37825830
Sorry.....it was my mistake...pure cockpit error.

Thanks for the help...you have the points.
0

Featured Post

Live: Real-Time Solutions, Start Here

Receive instant 1:1 support from technology experts, using our real-time conversation and whiteboard interface. Your first 5 minutes are always free.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
Windows 10 IE Certificate Issue 10 45
By pass website on ASA for Websense 4 70
java stored proc example 9 29
login jsp example 24 46
Introduction Java can be integrated with native programs using an interface called JNI(Java Native Interface). Native programs are programs which can directly run on the processor. JNI is simply a naming and calling convention so that the JVM (Java…
Java Flight Recorder and Java Mission Control together create a complete tool chain to continuously collect low level and detailed runtime information enabling after-the-fact incident analysis. Java Flight Recorder is a profiling and event collectio…
Viewers will learn about arithmetic and Boolean expressions in Java and the logical operators used to create Boolean expressions. We will cover the symbols used for arithmetic expressions and define each logical operator and how to use them in Boole…
Viewers will learn about basic arrays, how to declare them, and how to use them. Introduction and definition: Declare an array and cover the syntax of declaring them: Initialize every index in the created array: Example/Features of a basic arr…

785 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question