Java网络编程从入门到精通(5):使用InetAddress类的getHostName方法获得域名

简介:
该方法可以得到远程主机的域名,也可以得到本机名。getHostName 方法的定义如下:
public  String getHostName()
     下面是三种创建InetAddress 对象的方式,在这三种方式中,getHostName 返回的值是不同的。
1 使用 getLocalHost 方法创建 InetAddress 对象
如果InetAddress 对象是用getLocalHost 方法创建的,getHostName 返回的是本机名。如下面的代码所示:
InetAddress address  =  InetAddress.getLocalHost();
System.out.println(address.getHostName());  
//  输出本机名
2 使用域名创建 InetAddress 对象
用域名作为getByName getAllByName 方法的参数调用这两个方法后,系统会自动记住这个域名。当调用getHostName 方法时,就无需再访问DNS 服务器,而是直接将这个域名返回。如下面的代码所示:
InetAddress address  =  InetAddress.getByName( " www.oracle.com " );
System.out.println(address.getHostName());  
//  无需访问DNS服务器,直接返回域名
3 使用 IP 地址创建 InetAddress 对象
使用IP 地址创建InetAddress 对象时(getByName getAllByName getByAddress 方法都可以通过IP 地址创建InetAddress 对象),并不需要访问DNS 服务器。因此,通过DNS 服务器查找域名的工作就由getHostName 方法来完成。如果这个IP 地址不存在或DNS 服务器不允许进行IP 地址和域名的映射,getHostName 方法就直接返回这个IP 地址。如下面的代码所示:
InetAddress address  =  InetAddress.getByName( " 141.146.8.66 " );
System.out.println(address.getHostName());  
//  需要访问DNS服务器才能得到域名
InetAddress address  =  InetAddress.getByName( " 1.2.3.4 " );   //  IP地址不存在
System.out.println(address.getHostName());   //  直接返回IP地址
     从上面的三种情况可以看出,只有通过使用IP 地址创建的InetAddress 对象调用getHostName 方法时才访问DNS 服务器。在其他情况,getHostName 方法并不会访问DNS 服务器,而是直接将域名或本机名返回。下面的代码演示了在不同情况下如何使用getHostName 方法,并计算了各种情况所需的毫秒数。
   package  mynet;
  
  
import  java.net. * ;
  
  
public   class  DomainName
  {
      
public   static   void  main(String[] args)  throws  Exception
      {
          
long  time  =   0 ;
          
//  得到本机名
          InetAddress address1  =  InetAddress.getLocalHost();
          System.out.println(
" 本机名:  "   +  address1.getHostName());
          
//  直接返回域名
          InetAddress address2  =  InetAddress.getByName( " www.oracle.com " );
          time 
=  System.currentTimeMillis();
          System.out.print(
" 直接得到域名:  "   +  address2.getHostName());
          System.out.println(
"   所用时间: "
                          
+  String.valueOf(System.currentTimeMillis()  -  time)  +   "  毫秒 " );
          
//  通过DNS查找域名
          InetAddress address3  =  InetAddress.getByName( " 141.146.8.66 " );
          System.out.println(
" address3:   "   +  address3);   //  域名为空
          time  =  System.currentTimeMillis();
          System.out.print(
" 通过DNS查找域名:  "   +  address3.getHostName());
          System.out.println(
"   所用时间: "   +  String.valueOf(System.currentTimeMillis()  -  time) +   "  毫秒 " );
          System.out.println(
" address3:   "   +  address3);   //  同时输出域名和IP地址
      }
  }    
     运行结果:
本机名: ComputerName
直接得到域名: www.oracle.com  所用时间:
0  毫秒
address3:  /
141.146.8.66
通过DNS查找域名: bigip-otn-portal.oracle.com  所用时间:
92  毫秒
address3:  bigip-otn-portal.oracle.com/
141.146.8.66
从上面的运行结果可以看出,第一个毫秒数是0 ,而第二个毫秒数是92 。这说时,使用域名创建的InetAddress 对象在使用getHostName 方法时并不访问DNS 服务器,而使用IP 地址创建的InetAddress 对象在使用getHostName 方法时需要访问DNS 服务器。对于第三个毫秒数,可能多次运行DomainName 后会越来越小,这是因为DNS 服务器的缓存的缘故。但一般这个数都会比0 大。也许有很多人会问,第二行和第四行得到的域名怎么不一样,其实www.oracle.com bigip-otn-portal.oracle.com 都是 oracle 的域名,我们也可以通过 http:// bigip-otn-portal.oracle.com 来访问 oracle 的官方网站。至于这两个域名有什么区别,将在下面的文章中讨论。



 本文转自 androidguy 51CTO博客,原文链接:http://blog.51cto.com/androidguy/214810,如需转载请自行联系原作者

相关实践学习
基于函数计算快速搭建Hexo博客系统
本场景介绍如何使用阿里云函数计算服务命令行工具快速搭建一个Hexo博客。
相关文章
|
1天前
|
存储 Java
Java动态转发代理IP的实现方法
Java动态转发代理IP的实现方法
17 11
|
1天前
|
监控 Java 开发者
深入理解 Java 网络编程和 NIO
【4月更文挑战第19天】Java网络编程基于Socket,但NIO(非阻塞I/O)提升了效率和性能。NIO特点是非阻塞模式、选择器机制和缓冲区,适合高并发场景。使用NIO涉及通道、选择器和事件处理,优点是高并发、资源利用率和可扩展性,但复杂度、错误处理和性能调优是挑战。开发者应根据需求选择是否使用NIO,并深入理解其原理。
|
2天前
|
Java
Java接口中可以定义哪些方法?
【4月更文挑战第13天】
5 0
Java接口中可以定义哪些方法?
|
3天前
|
网络协议 Java API
深度剖析:Java网络编程中的TCP/IP与HTTP协议实践
【4月更文挑战第17天】Java网络编程重在TCP/IP和HTTP协议的应用。TCP提供可靠数据传输,通过Socket和ServerSocket实现;HTTP用于Web服务,常借助HttpURLConnection或Apache HttpClient。两者结合,构成网络服务基础。Java有多种高级API和框架(如Netty、Spring Boot)简化开发,助力高效、高并发的网络通信。
|
8天前
|
Java Shell
Java 21颠覆传统:未命名类与实例Main方法的编码变革
Java 21颠覆传统:未命名类与实例Main方法的编码变革
10 0
|
10天前
|
Java
Java中关于ConditionObject的signal()方法的分析
Java中关于ConditionObject的signal()方法的分析
21 4
|
9天前
|
安全 算法 Java
深入理解Java并发编程:线程安全与性能优化
【4月更文挑战第11天】 在Java中,高效的并发编程是提升应用性能和响应能力的关键。本文将探讨Java并发的核心概念,包括线程安全、锁机制、线程池以及并发集合等,同时提供实用的编程技巧和最佳实践,帮助开发者在保证线程安全的前提下,优化程序性能。我们将通过分析常见的并发问题,如竞态条件、死锁,以及如何利用现代Java并发工具来避免这些问题,从而构建更加健壮和高效的多线程应用程序。
|
1天前
|
安全 Java
深入理解 Java 多线程和并发工具类
【4月更文挑战第19天】本文探讨了Java多线程和并发工具类在实现高性能应用程序中的关键作用。通过继承`Thread`或实现`Runnable`创建线程,利用`Executors`管理线程池,以及使用`Semaphore`、`CountDownLatch`和`CyclicBarrier`进行线程同步。保证线程安全、实现线程协作和性能调优(如设置线程池大小、避免不必要同步)是重要环节。理解并恰当运用这些工具能提升程序效率和可靠性。
|
2天前
|
安全 Java
java多线程(一)(火车售票)
java多线程(一)(火车售票)
|
2天前
|
安全 Java 调度
Java并发编程:深入理解线程与锁
【4月更文挑战第18天】本文探讨了Java中的线程和锁机制,包括线程的创建(通过Thread类、Runnable接口或Callable/Future)及其生命周期。Java提供多种锁机制,如`synchronized`关键字、ReentrantLock和ReadWriteLock,以确保并发访问共享资源的安全。此外,文章还介绍了高级并发工具,如Semaphore(控制并发线程数)、CountDownLatch(线程间等待)和CyclicBarrier(同步多个线程)。掌握这些知识对于编写高效、正确的并发程序至关重要。

热门文章

最新文章