Click here to Skip to main content
13,799,624 members
Click here to Skip to main content
Add your own
alternative version


72 bookmarked
Posted 26 Nov 2004

UDP Send and Receive using threads in VB.NET

, 26 Nov 2004
Rate this:
Please Sign up or sign in to vote.
This article describes how to send and receive data without making the user interface to halt, in VB.NET using UDP..


When I first started with network programming I was unable to get a clean networking project without all the advanced stuff, that is why I'm submitting this. This article introduces how to use UDP/IP to send and receive data between two computers in a network. This also demonstrates the use of threads to send and receive data so that the user interface doesn't get stuck while sending and receiving data. In the receive program there is a cool section which converts the received message to bit format. That is also a simple technique which anybody can understand.

Anybody can use this program in a fair manner. And if you want to add more advanced features feel free to ask. I'm also going to submit a TCP/IP VC++.NET version of this program so that it may be more useful to you.


This program uses UdpClient to send and receive data. This means that it uses the User Datagram Protocol to communicate. The main advantage of UDP is that it works three times faster than TCP. But beware if you are using an unreliable network, data loss can occur.

Using UDP

When using UDP in VB.NET you must first create a UdpClient like this. Make sure you import Imports System.Net.Sockets in the project:

Dim udpClient As New UdpClient

How to send

Dim GLOIP As IPAddress 
Dim GLOINTPORT As Integer 
Dim bytCommand As Byte() = New    Byte() {}

The variables declared above are used in the code below:

GLOIP = IPAddress.Parse(txtIP.Text)
GLOINTPORT = txtPort.Text
udpClient.Connect(GLOIP, GLOINTPORT)
bytCommand = Encoding.ASCII.GetBytes(txtMessage.Text)
pRet = udpClient.Send(bytCommand, bytCommand.Length)
Console.WriteLine("No of bytes send " & pRet)

First of all, we have to assign an IP address to the GLOIP variable. In VB.NET we use IPAddress.Parse(" ") to get the IP address from a String. Of course getting the port is as simple as assigning the value.

Then we use the UdpClient.Connect(hostname as String, port as integer) to connect.

Then comes the tricky part, converting the string message to the Byte() format. Once you do this, you just have to use the UdpClient.Send() method to send the data and it will pass an integer value indicating the number of bytes send.

How to receive

Public receivingUdpClient As UdpClient
Public RemoteIpEndPoint As New _
      System.Net.IPEndPoint(System.Net.IPAddress.Any, 0)
Public ThreadReceive As System.Threading.Thread
Dim SocketNO As Integer

The variables declared above are used in the code below:

SocketNO = txtSocket.Text
receivingUdpClient = New System.Net.Sockets.UdpClient(SocketNO)
ThreadReceive = _
   New System.Threading.Thread(AddressOf ReceiveMessages)

The above code is placed wherever you want to start the receive process. The code starts the thread to receive so that the interface doesn't get stuck by waiting for the receive. The thread assigns ReceiveMessage function to do the receive process.

Here is the basic coding in the ReceiveMessage function:

Dim receiveBytes As [Byte]() = receivingUdpClient.Receive(RemoteIpEndPoint)
txtIP.Text = RemoteIpEndPoint.Address.ToString
Dim BitDet As BitArray
BitDet = New BitArray(receiveBytes)
Dim strReturnData As String = _

This code receives the message. As you can see in the coding the IPEndPoint is configured so that it will receive from any IP address. The receiving port is assigned during the thread calling time.

This also demonstrates the conversion of Byte() to String so that you can do whatever you like with the received message.

How to get the bit details

For j = 0 To BitDet.Length - 1
    If BitDet(j) = True Then
        Console.Write("1 ")
        tempStr2 = tempStr
        tempStr = " 1" + tempStr2
        Console.Write("0 ")
        tempStr2 = tempStr
        tempStr = " 0" + tempStr2
    End If
    i += 1
    If i = 8 And j <= (BitDet.Length - 1) Then
        line += 1
        i = 0
        TextBox1.Text = TextBox1.Text + tempStr
        tempStr = ""
        tempStr2 = ""
        TextBox1.Text = TextBox1.Text + vbCrLf
        If j <> (BitDet.Length - 1) Then
            TextBox1.Text = TextBox1.Text + line.ToString & ") "
        End If
    End If

This simple code gets the message bit pattern and pastes it in a textbox. Make sure that the Multiline property of the text box is set to True.


This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here


About the Author

Kumudu Gunasekara
Software Developer (Senior)
Sri Lanka Sri Lanka
I'm a software engineer working in a leading IT company in Sri Lanka. I'm a Microsoft Certified Technology Specialist. I used to submit articles that I taught would benefit fellow programmers. Unfortunately my last submission was more than 7 years ago. I'm thinking about starting again soon. Check out my full bio
My web site

You may also be interested in...


Comments and Discussions

GeneralVB 2005 Pin
Steve Blencowe14-Dec-05 1:07
memberSteve Blencowe14-Dec-05 1:07 
GeneralNew to VB Pin
xlbder10-Oct-05 7:55
memberxlbder10-Oct-05 7:55 
Generalgreat stuff Pin
Oxcarz19-Jul-05 9:48
memberOxcarz19-Jul-05 9:48 
GeneralGreat Article! Pin
tupacs017-Jun-05 21:00
membertupacs017-Jun-05 21:00 
GeneralGood Article Pin
DeadConcrete10-Dec-04 20:53
memberDeadConcrete10-Dec-04 20:53 
GeneralGreat article Pin
Anonymous26-Nov-04 9:27
memberAnonymous26-Nov-04 9:27 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Praise Praise    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

Permalink | Advertise | Privacy | Cookies | Terms of Use | Mobile
Web02 | 2.8.181207.3 | Last Updated 26 Nov 2004
Article Copyright 2004 by Kumudu Gunasekara
Everything else Copyright © CodeProject, 1999-2018
Layout: fixed | fluid