為什麼 Ping 成功時 `InetAddress.isReachable()` 有時會回傳 False?
儘管Ping 可訪問,InetAddress.isReachable() 返回False
在Java 中,InetAddress.isReachable() 用於檢查給定的IP 是否位址可以從目前機器存取。令人驚訝的是,即使您可以成功 ping IP 位址,您也可能會遇到此方法傳回 false 的情況。
出現這種不一致的原因是 InetAddress.isReachable() 不使用與 ping 相同的機制。相反,它採用底層平台的互聯網控制訊息協定 (ICMP) 實現,這可能與 ping 命令不同。
平台獨立解決方案
解決為了解決這種差異並獲得平台獨立性,請考慮以下方法:
private static boolean isReachable(String addr, int openPort, int timeOutMillis) { // Any Open port on other machine // openPort = 22 - ssh, 80 or 443 - webserver, 25 - mailserver etc. try (Socket soc = new Socket()) { soc.connect(new InetSocketAddress(addr, openPort), timeOutMillis); return true; } catch (IOException ex) { return false; } }
此解決方案檢查透過嘗試使用TCP 協定連接到開放連接埠(例如,用於SSH 的連接埠22、用於Web 伺服器的連接埠80 或443等)來取得指定的 IP 位址。如果連線成功,則認為IP位址可達;
簡潔版本
為簡潔起見,您可以將程式碼壓縮如下:
private static boolean isReachable(String addr, int openPort, int timeOutMillis) { try (Socket soc = new Socket()) { soc.connect(new InetSocketAddress(addr, openPort), timeOutMillis); return true; } catch (IOException ex) { return false; } }
此平台無關方法提供了一種可靠的方法來確定IP 位址的可及性,而不管底層ICMP 如何實施。
以上是為什麼 Ping 成功時 `InetAddress.isReachable()` 有時會回傳 False?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undress AI Tool
免費脫衣圖片

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

JavaNIO是Java1.4引入的新型IOAPI,1)面向緩衝區和通道,2)包含Buffer、Channel和Selector核心組件,3)支持非阻塞模式,4)相比傳統IO更高效處理並發連接。其優勢體現在:1)非阻塞IO減少線程開銷,2)Buffer提升數據傳輸效率,3)Selector實現多路復用,4)內存映射加快文件讀寫。使用時需注意:1)Buffer的flip/clear操作易混淆,2)非阻塞下需手動處理不完整數據,3)Selector註冊需及時取消,4)NIO並非適用於所有場景。

HashMap在Java中通過哈希表實現鍵值對存儲,其核心在於快速定位數據位置。 1.首先使用鍵的hashCode()方法生成哈希值,並通過位運算轉換為數組索引;2.不同對象可能產生相同哈希值,導致衝突,此時以鍊錶形式掛載節點,JDK8後鍊錶過長(默認長度8)則轉為紅黑樹提升效率;3.使用自定義類作鍵時必須重寫equals()和hashCode()方法;4.HashMap動態擴容,當元素數超過容量乘以負載因子(默認0.75)時,擴容並重新哈希;5.HashMap非線程安全,多線程下應使用Concu

單例設計模式在Java中通過私有構造器和靜態方法確保一個類只有一個實例並提供全局訪問點,適用於控制共享資源的訪問。實現方式包括:1.懶加載,即首次請求時才創建實例,適用於資源消耗大且不一定需要的情況;2.線程安全處理,通過同步方法或雙重檢查鎖定確保多線程環境下只創建一個實例,並減少性能影響;3.餓漢式加載,在類加載時直接初始化實例,適合輕量級對像或可接受提前初始化的場景;4.枚舉實現,利用Java枚舉天然支持序列化、線程安全及防止反射攻擊的特性,是推薦的簡潔可靠方式。不同實現方式可根據具體需求選

Optional能清晰表達意圖並減少null判斷的代碼噪音。 1.Optional.ofNullable是處理可能為null對象的常用方式,如從map中取值時可結合orElse提供默認值,邏輯更清晰簡潔;2.通過鍊式調用map實現嵌套取值,安全地避免NPE,任一環節為null則自動終止並返回默認值;3.filter可用於條件篩選,滿足條件才繼續執行後續操作,否則直接跳到orElse,適合輕量級業務判斷;4.不建議過度使用Optional,如基本類型或簡單邏輯中其反而增加複雜度,部分場景直接返回nu

處理Java中的字符編碼問題,關鍵是在每一步都明確指定使用的編碼。 1.讀寫文本時始終指定編碼,使用InputStreamReader和OutputStreamWriter並傳入明確的字符集,避免依賴系統默認編碼。 2.在網絡邊界處理字符串時確保兩端一致,設置正確的Content-Type頭並用庫顯式指定編碼。 3.謹慎使用String.getBytes()和newString(byte[]),應始終手動指定StandardCharsets.UTF_8以避免平台差異導致的數據損壞。總之,通過在每個階段

String不可變,StringBuilder可變且非線程安全,StringBuffer可變且線程安全。 1.String一旦創建內容不可修改,適合少量拼接;2.StringBuilder適合單線程頻繁拼接,性能高;3.StringBuffer適合多線程共享場景,但性能略低;4.合理設置初始容量、避免循環中用String拼接能提升性能。

遇到java.io.NotSerializableException的核心解決方法是確保所有需序列化的類實現Serializable接口,並檢查嵌套對象的序列化支持。 1.給主類添加implementsSerializable;2.確保類中自定義字段對應的類也實現Serializable;3.用transient標記不需要序列化的字段;4.檢查集合或嵌套對像中的非序列化類型;5.查看異常信息定位具體哪個類未實現接口;6.對無法修改的類考慮替換設計,如保存關鍵數據或使用可序列化的中間結構;7.考慮改

JavaSocket編程是網絡通信的基礎,通過Socket實現客戶端與服務器間的數據交換。 1.Java中Socket分為客戶端使用的Socket類和服務器端使用的ServerSocket類;2.編寫Socket程序需先啟動服務器監聽端口,再由客戶端發起連接;3.通信過程包括連接建立、數據讀寫及流關閉;4.注意事項包括避免端口衝突、正確配置IP地址、合理關閉資源及支持多客戶端的方法。掌握這些即可實現基本的網絡通信功能。
