黑马程序员 java 网络编程

本文详细介绍了Java网络编程中的InetAddress类及其方法,如getByAddress、getByName、isReachable等,同时阐述了如何通过域名和IP地址进行Socket连接。此外,文章还讨论了拒绝通过IP地址访问网站的原因及DNS缓存的配置方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Java网络 编程
InetAddress类
InetAddress类是个表示ip地址的类。
InetAddress没有构造函数,是用它的static方法类返回InetAddress对象的。
getByAddress
public static InetAddress getByAddress(byte[] addr) throws UnknownHostException
public static InetAddress getByAddress(String host, byte[] addr) throws UnknownHostException
无论参数addr所表示的ip是否存在,都会创建一个这个ip地址的InetAddress对象。第二个方法中的host主机名也不一定要是addr所表达的ip主机的真正名字。这个host只是用来表示别名。
getByName
public static InetAddress getByName(String host) throws UnknownHostException
public static InetAddress[] getAllByName(String host) throws UnknownHostException
isReachable方法
public boolean isReachable(int timeout) throws IOException
public boolean isReachable(NetworkInterface netif, int ttl, int timeout) throws IOException
第一个重载形式有一个timeout参数,可以通过这个参数设置连接超时(单位:毫秒)。第二个重载形式多了两个参数:netif和ttl。通过netif参数可以使用一个NetworkInterface对象来确定客户端使用哪个网络接口来测试主机的连通性。ttl是指测试连通性过程中的最大连接跃点数(从客户机到达远程主机所经过的最大路由数就是最大连接跃点数。
isReachable方法是通过连接主机的echo端口来确定客户端和服务端是否可连通。但在Internet上使用这个方法可能会因为放火墙等因素而无法连通远程主机(实际上,远程主机是可以连通的),因此,isReachable在Internet上并不可靠。但我们可以将isReachable方法应用。
拒绝通过ip地址访问网站(HTTP状态号:403)
有些网站明明输入的ip是对的,但是却访问不了网站,这是因为服务器通过检验HTTP协议的请求头中的Host字段防止用户直接通过ip地址来访问网站。
DNS缓存
//把DNS缓存超时设置为args[1]秒
java.security.Security.setProperty("networkaddress.cache.ttl",args[1]);
Security类www.2cto.com
Thisclass centralizes all security properties and common securitymethods. One of its primary uses is to manage providers.
networkaddress.cache.ttl属性
在jdk的/usr/lib/jvm/jdk7/jre/lib/security/java.security文件中
参数args[1]:表示缓存时间,-1表示永久缓存。
NetworkInterface类(网络接口信息)
这个类也没有构造函数。
public static NetworkInterface getByInetAddress(InetAddress addr) throws SocketException
public static NetworkInterface getByName(String name) throws SocketException
Socket编程
在客户端可以通过两种方式来连接服务端:ip和 域名
在java中,已经将域名解析功能包含在Socket类中,所以我们可以想使用ip一样使用域名。
 

### 黑马程序员 Java 并发编程 笔记 Java并发编程是一个复杂而重要的主题,涵盖了多线程、同步机制以及高级并发工具等内容。对于希望深入理解这一领域的人来说,找到合适的资源至关重要。 #### 多线程基础概念 在Java中,创建新线程可以通过继承`Thread`类或实现`Runnable`接口来完成。每种方法都有其特点和适用场景[^1]。例如: ```java // 继承 Thread 类的方式 class MyThread extends Thread { @Override public void run() { System.out.println("子线程运行"); } } // 实现 Runnable 接口的方式 class MyRunnable implements Runnable { @Override public void run() { System.out.println("通过 Runnable 创建的子线程"); } } ``` #### 同步控制与锁机制 为了防止多个线程同时访问共享数据而导致的数据不一致问题,可以采用内置锁(`synchronized`)或者显式的锁对象如`ReentrantLock`来进行同步控制[^2]。下面展示了一个简单的自定义锁的例子: ```java public class SpinLock { private final AtomicReference<Thread> atomicReference = new AtomicReference<>(); public void lock() { Thread current = Thread.currentThread(); while (!atomicReference.compareAndSet(null, current)) {} } public void unlock() { Thread current = Thread.currentThread(); atomicReference.compareAndSet(current, null); } } ``` #### 高级并发特性 除了基本的线程管理和同步外,Java还提供了诸如`ExecutorService`框架用于管理线程池;`CountDownLatch`, `CyclicBarrier`等协调器帮助不同线程之间协作;还有像`CompletableFuture`这样的异步处理API。 #### 学习建议 针对想要系统化掌握Java并发编程的学习者来说,《黑马程序员》系列教程是非常好的起点之一。该套教材不仅覆盖了上述提到的基础知识点,还包括了许多实际项目案例分析,有助于加深理解和应用能力。此外,在线平台上的相关视频课程也值得推荐给初学者作为辅助材料。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值