Java NIO實(shí)例UDP發(fā)送接收數(shù)據(jù)代碼分享
Java的NIO包中,有一個(gè)專門用于發(fā)送UDP數(shù)據(jù)包的類:DatagramChannel,UDP是一種無連接的網(wǎng)絡(luò)協(xié)議,
一般用于發(fā)送一些準(zhǔn)確度要求不太高的數(shù)據(jù)等。
完整的服務(wù)端程序如下:
public class StatisticsServer {
//每次發(fā)送接收的數(shù)據(jù)包大小
private final int MAX_BUFF_SIZE = 1024 * 10;
//服務(wù)端監(jiān)聽端口,客戶端也通過該端口發(fā)送數(shù)據(jù)
private int port;
private DatagramChannel channel;
private Selector selector;
private ScheduledExecutorService es = Executors.newScheduledThreadPool(1);
public void init() throws IOException {
//創(chuàng)建通道和選擇器
selector = Selector.open();
channel = DatagramChannel.open();
//設(shè)置為非阻塞模式
channel.configureBlocking(false);
channel.socket().bind(new InetSocketAddress(port));
//將通道注冊(cè)至selector,監(jiān)聽只讀消息(此時(shí)服務(wù)端只能讀數(shù)據(jù),無法寫數(shù)據(jù))
channel.register(selector, SelectionKey.OP_READ);
//使用線程的方式,保證服務(wù)端持續(xù)等待接收客戶端數(shù)據(jù)
es.scheduleWithFixedDelay(new Runnable() {
@Override
public void run() {
try {
while(selector.select() > 0) {
Iterator<SelectionKey> iterator = selector.selectedKeys().iterator();
while(iterator.hasNext()) {
SelectionKey key = iterator.next();
try {
iterator.remove();
if(key.isReadable()) {
//接收數(shù)據(jù)
doReceive(key);
}
} catch (Exception e) {
logger.error("SelectionKey receive exception", e);
try {
if (key != null) {
key.cancel();
key.channel().close();
}
} catch (ClosedChannelException cex) {
logger.error("Close channel exception", cex);
}
}
}
}
} catch (IOException e) {
logger.error("selector.select exception", e);
}
}
}, 0L, 2L, TimeUnit.MINUTES);
}
//處理接收到的數(shù)據(jù)
private void doReceive(SelectionKey key) throws IOException {
String content = "";
DatagramChannel sc = (DatagramChannel) key.channel();
ByteBuffer buffer = ByteBuffer.allocate(MAX_BUFF_SIZE);
buffer.clear();
sc.receive(buffer);
buffer.flip();
while(buffer.hasRemaining()) {
byte[] buf = new byte[buffer.limit()];
buffer.get(buf);
content += new String(buf);
}
buffer.clear();
logger.debug("receive content="+content);
if(StringUtils.isNotBlank(content)) {
doSave(content);
}
}
}
客戶端發(fā)送完整例子如下:
DatagramChannel channel = DatagramChannel.open();
StringBuilder sb = new StringBuilder();
sb.append("2017-03-09 12:30:00;")
.append("aaa")
.append("testapp;")
.append("test.do;")
.append("param=hello;")
.append("test;")
.append("100;")
.append("1");
ByteBuffer buffer = ByteBuffer.allocate(10240);
buffer.clear();
buffer.put(sb.toString().getBytes());
buffer.flip();
//此處IP為服務(wù)端IP地址,端口和服務(wù)端的端口一致
int n = channel.send(buffer, new InetSocketAddress("127.0.0.1", 8080));
System.out.println(n);
//每次數(shù)據(jù)發(fā)送完畢之后,一定要調(diào)用close方法,來關(guān)閉占用的udp端口,否則程序不結(jié)束,端口不會(huì)釋放
channel.close();
總結(jié)
以上就是本文關(guān)于Java NIO實(shí)例UDP發(fā)送接收數(shù)據(jù)代碼分享的全部內(nèi)容,希望對(duì)大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:
Javaweb應(yīng)用使用限流處理大量的并發(fā)請(qǐng)求詳解
有什么問題可以隨時(shí)留言,小編會(huì)及時(shí)回復(fù)大家的。感謝朋友們對(duì)本站的支持!
相關(guān)文章
Java生產(chǎn)者和消費(fèi)者例子_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
生產(chǎn)者-消費(fèi)者(producer-consumer)問題,也稱作有界緩沖區(qū)(bounded-buffer)問題,兩個(gè)進(jìn)程共享一個(gè)公共的固定大小的緩沖區(qū)。下文通過實(shí)例給大家介紹java生產(chǎn)者和消費(fèi)者,感興趣的朋友一起學(xué)習(xí)吧2017-05-05
修改Springboot默認(rèn)序列化工具Jackson配置的實(shí)例代碼
這篇文章主要介紹了如何修改Springboot默認(rèn)序列化工具Jackson的配置,當(dāng)Spring容器中存在多個(gè)同類型的Bean時(shí),默認(rèn)情況下最后一個(gè)創(chuàng)建的Bean將作為首選Bean,文中通過代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2024-02-02
java基本教程之java線程等待與java喚醒線程 java多線程教程
這篇文章主要介紹了對(duì)線程等待/喚醒方法,文中使用了多個(gè)示例,大家參考使用吧2014-01-01
Java Adapter 適配器模式(類適配器,對(duì)象適配器)優(yōu)缺點(diǎn)對(duì)比
這篇文章主要介紹了Java 適配器模式(類適配器,對(duì)象適配器)優(yōu)缺點(diǎn)對(duì)比的相關(guān)資料,java 適配器在基礎(chǔ)知識(shí)中還是比較重要的,這里就說下如何使用,需要的朋友可以參考下2016-12-12
Java使用ReentrantLock進(jìn)行加解鎖的示例代碼
在多線程編程中,為了確保多個(gè)線程在訪問共享資源時(shí)不會(huì)發(fā)生沖突,我們通常需要使用 鎖 來同步對(duì)資源的訪問,本文將深入探討如何優(yōu)雅地使用 ReentrantLock,避免常見的坑點(diǎn),并提升代碼的可維護(hù)性,需要的朋友可以參考下2025-04-04
解決Springboot項(xiàng)目打包后的頁面丟失問題(thymeleaf報(bào)錯(cuò))
這篇文章主要介紹了解決Springboot項(xiàng)目打包后的頁面丟失問題(thymeleaf報(bào)錯(cuò)),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-11-11
Spark隨機(jī)森林實(shí)現(xiàn)票房預(yù)測
這篇文章主要為大家詳細(xì)介紹了Spark隨機(jī)森林實(shí)現(xiàn)票房預(yù)測,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-08-08

