1、如何编写java管道程序,给出实例及应用。
2、文件的分割与合并。(http://www.knowsky.com/368018.html)
3、TCP与UDP的区别?
package com.interview01;
import java.io.*;
import util.P;
public class PipedStreamTest {
//分别用两个线程来读取,避免了出现死锁
public static void main(String[] args) {
Sender sender = new Sender();
Receiver receiver = new Receiver();
PipedOutputStream pos = sender.getOut();
PipedInputStream pis = receiver.getIn();
try {
pis.connect(pos);
sender.start();
receiver.start();
} catch(IOException e) {
e.printStackTrace();
}
}
}
class Sender extends Thread {
PipedOutputStream pos = new PipedOutputStream();
public void run() {
String msg = "hello world I am sender \n I am \r";
try {
pos.write(msg.getBytes());
} catch(IOException e) {
e.printStackTrace();
}
}
public PipedOutputStream getOut() {
return pos;
}
}
class Receiver extends Thread {
PipedInputStream pis = new PipedInputStream();
public void run() {
byte[] bytes = new byte[1024];
try {
int l = pis.read(bytes);
String s = new String(bytes);
P.p(s);
} catch(IOException e) {
e.printStackTrace();
}
}
public PipedInputStream getIn() {
return pis;
}
}
3、TCP与UDP的区别?
TCP---传输控制协议,提供的是面向连接、可靠的字节流服务。当客户和服务器彼此交换数据前,必须先在双方之间建立一个TCP连接,之后才能传输数据。TCP提供超时重发,丢弃重复数据,检验数据,流量控制等功能,保证数据能从一端传到另一端。
UDP---用户数据报协议,是一个简单的面向数据报的运输层协议。UDP不提供可靠性,它只是把应用程序传给IP层的数据报发送出去,但是并不能保证它们能到达目的地。由于UDP在传输数据报前不用在客户和服务器之间建立一个连接,且没有超时重发等机制,故而传输速度很快
UDP<wbr><br><wbr><wbr><wbr><wbr>UDP 与 TCP 的主要区别在于 <strong>UDP 不一定提供可靠的数据传输</strong>。事实上,该协议不能保证数据准确无误地到达目的地。UDP 在许多方面非常有效。当某个程序的目标是尽快地传输尽可能多的信息时(其中任意给定数据的重要性相对较低),可使用 UDP。ICQ 短消息使用 UDP 协议发送消息。<wbr><br><wbr><wbr><wbr><wbr>许多程序将使用单独的TCP连接和单独的UDP连接。重要的状态信息随可靠的TCP连接发送,而主数据流通过UDP发送。<br><strong><br>
TCP</strong><br><wbr><wbr><wbr><wbr>TCP的目的是提供可靠的数据传输,并在相互进行通信的设备或服务之间保持一个虚拟连接。TCP在数据包接收无序、丢失或在交付期间被破坏时,负责数据恢复。它通过为其发送的每个数据包提供一个序号来完成此恢复。记住,较低的网络层会将每个数据包视为一个独立的单元,因此,数据包可以沿完全不同的路径发送,即使它们都是同一消息的组成部分。这种路由与网络层处理分段和重新组装数据包的方式非常相似,只是级别更高而已。<br><wbr><wbr><wbr><wbr>为确保正确地接收数据,TCP要求在目标计算机成功收到数据时发回一个确认(即 ACK)。如果在某个时限内未收到相应的 ACK,将重新传送数据包。如果网络拥塞,这种重新传送将导致发送的数据包重复。但是,接收计算机可使用数据包的序号来确定它是否为重复数据包,并在必要时丢弃它。</wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>
TCP与UDP的选择<wbr><wbr><br><br><wbr><wbr><wbr><wbr>如果比较UDP包和TCP包的结构,很明显UDP包不具备TCP包复杂的可靠性与控制机制。与TCP协议相同,UDP的源端口数和目的端口数也都支持一台主机上的多个应用。一个16位的UDP包包含了一个字节长的头部和数据的长度,校验码域使其可以进行整体校验。(许多应用只支持UDP,如:多媒体数据流,不产生任何额外的数据,即使知道有破坏的包也不进行重发。)<wbr><wbr><br><wbr><wbr><wbr><wbr>很明显,<strong>当数据传输的性能必须让位于数据传输的完整性、可控制性和可靠性时,TCP协议是当然的选择。当强调传输性能而不是传输的完整性时,如:音频和多媒体应用,UDP是最好的选择。在数据传输时间很短,以至于此前的连接过程成为整个流量主体的情况下</strong>,UDP也是一个好的选择,如:DNS交换。把SNMP建立在UDP上的部分原因是设计者认为当发生网络阻塞时,UDP较低的开销使其有更好的机会去传送管理数据。TCP丰富的功能有时会导致不可预料的性能低下,但是我们相信在不远的将来,TCP可靠的点对点连接将会用于绝大多数的网络应用。<br><br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>
分享到:
相关推荐
整理的数据库的一些面试题 就业面试题库 ─ 数据库部分
Redis常见的一些面试题,给有需要的人。
mysql常见的一些面试题,帮助有需要的你。
11.md 一些面试题 General 12.md BAT及互联网公司2014前端笔试面试题--HTML,CSS篇 HTML,CSS 13.md BAT及互联网公司2014前端笔试面试题--JavaScript篇 JavaScript 14.md 收集的前端面试题和答案 General 15.md 各...
python面试题、知识点,用于程序员应聘学习参考,提供代码+题型等资料 python面试题、知识点,用于程序员应聘学习参考,提供代码+题型等资料 python面试题、知识点,用于程序员应聘学习参考,提供代码+题型等资料 ...
vue常见面试题.zip vue常见面试题.zipvue常见面试题.zip
许多面试题看似简单,却需要深厚的基本功...此外,还有一些面试题考查面试者敏捷的思维能力。 分析这些面试题,本身包含很强的趣味性;而作为一名研发人员,通过对这些面试题的深入剖析则可进一步增强自身的内功。
JavaOOP面试题 Java集合/泛型面试题 Java异常面试题 Java中的IO与NIO面试题 Java反射面试题 Java序列化面试题 Java注解面试题 多线程&并发面试题 JVM面试题 Mysql面试题 Redis面试题 Memcached面试题 MongoDB面试题 ...
云计算面试题之ELK面试题,运维工程师必备云计算面试题之ELK面试题,运维工程师必备云计算面试题之ELK面试题,运维工程师必备云计算面试题之ELK面试题,运维工程师必备云计算面试题之ELK面试题,运维工程师必备...
分析这些试题,本身包含很强的趣味性:而作为一名研发人员,通过对这些面试题的深入剖析则可进一步增强自身的内功。... 本文的写作目的并不在于提供C/C++程序员...此外,还有一些面试题考查面试者敏捷的思维能力。....
各大IT公司的笔试面试题 包括联想 网易 华为 朗讯 IBM 百度 google 腾讯 普天 阿里巴巴 贝尔 思科 微软 网易 大唐
Spring面试题
最全的j2EE面试题,题量大、经典,是我面试的整理试题 1、java笔试题大集合 2、各个公司面试题 3、J2EE初学者面试题 4、J2EE面试题(打码查错题) 5、java_华为笔试题 6、java常见面试题 7、java程序员面试宝典 8、...
从各大网收集的一些java和android的笔试题,看完了看懂了保证你笔试不怕任何人公司
最近要求职的人可以看看,会有好处的。里面的内容还很丰富。
(啰嗦一句,作者认为,技术分享才能无界,感恩、帮助才能获得...因为互联网本身有一定的模型分层,所以本文,根据模型分层,分析协议和规则,对一些面试题以及书上的原理进行阐述。希望能够帮助到正在面临找工作的人。
vue3面试题
java高级软件工程师面试题大全及答,一些公司的面试题,对于正在找工作应对面试的朋友或许有点帮助。java高级软件工程师面试题大全及答,一些公司的面试题,对于正在找工作应对面试的朋友或许有点帮助
大数据面试题V3.0完成了。共523道题,679页,46w+字,来源于牛客870+篇面经。 主要分为以下几部分: Hadoop面试题:100道 Zookeeper面试题:21道 Hive面试题:47道 Flume面试题:11道 Kafka面试题:59到 HBase面试题...