|
Byte Ordering
Care must always be taken to account for any differences between the byte
ordering used by Intel Architecture and the byte ordering used on the wire by
individual transport protocols. Any reference to an address or port number passed to
or from a Windows Sockets routine must be in the network order for the
protocol being utilized. In the case of IP, this includes the IP address and port
fields of a sockaddr_in structure (but not the sin_family field).
Consider an application which normally contacts a server on the TCP port
corresponding to the "time" service, but which provides a mechanism for the user to
specify that an alternative port is to be used. The port number returned by
getservbyname() is already in network order, which is the format required for
constructing an address, so no translation is required. However if the user elects
to use a different port, entered as an integer, the application must convert
this from host to TCP/IP network order (using the WSAHtons() function) before
using it to construct an address. Conversely, if the application wishes to display
the number of the port within an address (returned via, e.g., getpeername()),
the port number must be converted from network to host order (using WSANtohs())
before it can be displayed.
Since the Intel Architecture and Internet byte orders are different, the
conversions described above are unavoidable. Application writers are cautioned that
they should use the standard conversion functions provided as part of WinSock
rather than writing their own conversion code, since future implementations of
WinSock are likely to run on systems for which the host order is identical to
the network byte order. Only applications which use the standard conversion
functions are likely to be portable.
Consider an application that normally contacts a server on the TCP port
corresponding to the "time" service, but provides a mechanism for the user to specify
an alternative port. The port number returned by getservbyname is already in network order, which is the format required for constructing an
address so no translation is required. However, if the user elects to use a
different port, entered as an integer, the application must convert this from
host to TCP/IP network order (using the WSAHtons function) before using it to construct an address. Conversely, if the
application were to display the number of the port within an address (returned by getpeername for example), the port number must be converted from network to host order
(using WSANtohs) before it can be displayed.
Since the Intel and Internet byte orders are different, the conversions
described above are unavoidable. Application writers are cautioned that they should
use the standard conversion functions provided as part of Windows Sockets rather than writing their own conversion code since future implementations of Windows Sockets are likely to run on systems for which the host order is identical to the
network byte order. Only applications that use the standard conversion functions
are likely to be portable.
| Last news from Greatis Software |
 |
|
Nostalgia .Net |
|
.Net is powerful, but not all-powerful, so sometimes we need to use Win32 API for our .Net applications. It's simple enough with Platform Invoke if you have Win32 skill, but we do not always have time to dig the ancient documentation, declare the special types that are compatible with Win32, find the values of the Win32's constants and so on. Nostalgia .Net offers several simple-to-use classes, and components that will allow you to forget about the headache of Win32 and just use the power of Win32 in your application the same way as you use the native. Net classes. More » |
| Recommended software for developers |
 |
|
Ultimate Pack |
|
Component pack for Delphi and C++ Builder that contains runtime form designer, runtime object inspector, print suite and much more for the very special price. More » |
 |
|
Form Designer .Net |
|
Unique runtime form design solution that allows to edit any form in .Net WinForms application at runtime without manual coding. Full C# source codes are available More » |
 |
|
Print Suite .Net |
|
Print Suite .Net is a set of components for easy printing texts, images and grids from your WinForms applications. Full C# source codes are available More » |
 |
|
Gradient Controls .Net |
|
Gradient Controls .Net offers controls with gradient background feature. Labels, panels and so on... Full C# source codes are available More » |
 |
|
Greatis iGrid |
|
iGrid plots drawing grid right over your desktop, so you can use it everywhere, with any drawing application without any special plugins for different graphic editors. More » |
Related LinksSoftware for Visual Studio .NET developers Software for Delphi and C++ Builder developers Software for Visual Basic 6 developers Delphi Tips&Tricks MegaDetailed.NET More Online Helps Win32 Programmer's Reference Win32 Multimedia Programmer's Reference OLE Programmer's Reference Microsoft Windows Pen API Programmer's Reference Microsoft Windows Sockets 2 Reference Microsoft Windows Telephony API (TAPI) Programmer's Reference Unix Manual Pages
|