一.概念 ▪ 什么是计算机网络? 计算机网络是指将地理位置不同的具有独立功能的多台计算机及其外部设备,通过通信线路连接起来,在网络操作系统, 网络管理软件及网络通信协议的管理和协调下,实现资源共享和信息传递的计算机系统. 从其中我们可以提取到以下内容: 1. 计算机网络的作用:资源共享和信息传递. 2. 计算机网络的组成: a) 计算机硬件:计算机(大中小型服务器,台式机.笔记本等).外部设备(路由器.交换机等).通信线路(双绞线.光纤等). b) 计算机软件:网络操作系统(Windows 20…
目录 01 网络编程 一.软件开发架构 1.1 CS架构 1.2 BS架构 二.网络理论前戏 2.1 简介 2.2 常见硬件 三.OSI七层协议(五层) 3.1 七层协议 3.2 五层协议 3.3 知识储备(ARP协议.API接口.SDK接口) 3.4 网络层详解 3.5 传输层详解 四.TCP协议 4.1 三次握手 4.2 四次挥手 五.UDP协议 01 网络编程 一.软件开发架构 1.1 CS架构 c:client 客户端 s:server 服务端 理解: 将客户端看成是去店里消费客人 将服…
UNIX网络编程----传输层:TCP.UDP.SCTP 一.概述 本章的焦点是传输层:包括TCP.UDP.和SCTP(流控制传输协议).SCTP是一个较新的协议,最初设计用于跨因特网传输电话信令. UDP是一个简单的.不可靠的数据报协议.TCP是一个复杂.可靠的字节流协议.SCTP与TCP类似之处在于它也是一个可靠的数据报协议,但它还提供消息边界.传输级别多宿支持以及将头端阻塞减少到最小的一种方法.需要关注的几点:TCP的三路握手.TCP的链接终止序列和TCP的TIME_WAIT状态,SCTP…
一.概念 Java为了可移植性,不允许直接调用操作系统,而是由java.net包来提供网络功能.Java虚拟机负责提供与操作系统的实际连接. InetAddress    作用:封装计算机的IP地址和DNS(没有端口信息). 注:DNS是Domain Name System,域名系统.  特点:这个类没有构造方法.如果要得到对象,只能通过静态方法:getLocalHost().getByName(). getAllByName(). getAddress().getHostName(). Ine…
.引言 网络编程中TCP协议的三次握手和四次挥手的问题,在面试中是最为常见的知识点之一.很多读者都知道“三次”和“四次”,但是如果问深入一点,他们往往都无法作出准确回答. 本篇文章尝试使用动画图片的方式,来对这个知识点进行“脑残式”讲解(哈哈),期望读者们可以更加简单.直观地理解TCP网络通信交互的本质. 另外,社区里的另两篇文章<理论经典:TCP协议的3次握手与4次挥手过程详解>.<理论联系实际:Wireshark抓包分析TCP 3次握手.4次挥手过程>也是不错的入门文章,有兴趣…
脑残式网络编程入门(一):跟着动画来学TCP三次握手和四次挥手   http://www.52im.net/thread-1729-1-1.html     1.引言 网络编程中TCP协议的三次握手和四次挥手的问题,在面试中是最为常见的知识点之一.很多读者都知道“三次”和“四次”,但是如果问深入一点,他们往往都无法作出准确回答. 本篇文章尝试使用动画图片的方式,来对这个知识点进行“脑残式”讲解(哈哈),期望读者们可以更加简单.直观地理解TCP网络通信交互的本质. 另外,社区里的另两篇文章<理论经…
8.1.1 网络基础知识 计算机网络形式多样,内容繁杂.网络上的计算机要互相通信,必须遵循一定的协议.目前使用最广泛的网络协议是Internet上所使用的TCP/IP协议. 网络编程的目的就是指直接或间接地通过网络协议与其他计算机进行通讯.网络编程中有两个主要的问题,一个是如何准确的定位网络上一台或多台主机,另一个就是找到主机后如何可靠高效的进行数据传输.在TCP/IP协议中IP层主要负责网络主机的定位,数据传输的路由,由IP地址可以唯一地确定Internet上的一台主机.而TCP层则提供面向应…
Socket网络编程-IO各种概念及多路复用 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.操作系统相关知识 1>.同步和异步  函数或方法被调用的时候,调用者是否得到最终结果的. 直接得到最终结果结果的,就是同步调用. 不直接得到最终结果的,就是异步调用. 2>.阻塞和非阻塞 函数或方法调用的时候,是否立刻返回. 立即返回就是非阻塞调用; 不立即返回就是阻塞调用. 3>.同步,异步,阻塞,非阻塞之间的区别 同步.异步,与阻塞.非阻塞不相关. 同步.异步强调的是,…
Java Socket 网络编程心跳设计概念   1.一般是用来判断对方(设备,进程或其它网元)是否正常动行,一 般采用定时发送简单的通讯包,如果在指定时间段内未收到对方响应,则判断对方已经当掉.用于检测TCP的异常断开.一般是用来判断对方(设备,进程或其它 网元)是否正常动行,一般采用定时发送简单的通讯包,如果在指定时间段内未收到对方响应,则判断对方已经当掉.用于检测TCP的异常断开.基本原因是服务 器端不能有效的判断客户端是否在线也就是说,服务器无法区分客户端是长时间在空闲,还是已经掉线的情…
上一博客记录了UDP协议的关键要点,这部分记录TCP协议的关键要点. 24.3 传输控制协议(TRANSMISSION CONTROL PROTOCOL) TCP(Transmission Control Procotol )协议是一个面向连接,可靠的协议.TCP为了提供面向连接的服务,专门定义了连接创建,数据传输.连接终止阶段.TCP使用GBN和SR协议来提供可靠性.为了实现可靠性这个目标,TCP使用检验和来进行误差控制.重传来处理数据包丢失和冲突.同时还利用了应答和计数机制.在本节,首先讨论…
1 #coding=utf-8 2 #网络编程 3 4 #客户端建立socket套接字 5 #引入socket模块 6 import socket 7 #实例化一个套接字,2个参数分别是: IPV4.TCP 协议 8 s=socket.socket(socket.AF_INET, socket.SOCK_STREAM) 9 #建立连接,2个参数是: 网址.端口 10 s.connect(('www.baidu.com',80)) 11 #向服务器发送请求,传递的参数是:1.请求方式 2.地址 3…
1. UNIX 网络编程(第2版)第1卷:套接口API和X/Open 传输接口API PDFhttp://www.linuxidc.com/Linux/2014-04/100155.htm UNIX网络编程卷1:套接字联网API(第3版) 中文高清带完整书签 PDFhttp://www.linuxidc.com/Linux/2014-04/100222.htm UNIX网络编程.卷2:进程间通信(第2版)http://www.linuxidc.com/Linux/2013-01/77936.ht…
1.TCP和UDP协议 共同点:同为传输层协议 不同点: TCP:有连接,可靠 UPD 无连接,不保证可靠 TCP(即传输控制协议): 是一种面向连接的传输层协议,它是能提供高可靠性通信(即,数据无误,数据无丢失,数据无失序.数据无重复到达的通信) 适用情况: 适合于对传输质量要求较高,以及传输大量数据的通信. 在需要可靠数据传输的场合,通常使用TCP协议 QQ等即时通讯软件的用户登录账户管理相关的功能通常采用TCP协议 UDP(User Datagram Protocol)用户数据报协议 是不…
InerAddress: /**IP地址:在网络上唯一标示一台计算机 * 端口号:标示计算机上不同的应用程序 * java.net.InetAddress类:此类表示互联网协议 (IP) 地址. * 常用方法: * getByName(String host) 在给定主机名的情况下确定主机的 IP 地址. * getHostName() 获取此 IP地址的主机名. * getHostAddress()返回 IP 地址字符串(以文本表现形式). * getLocalHost() 返回本地主机. *…
由于UNIX和Win的socket大同小异,为了方便和大众化,这里先介绍Winsock编程. socket 网络编程的难点在入门的时候就是对基本函数的了解和使用,由于这些函数的结构往往比較复杂,參数大部分都是结构体,令人难以记忆和理解. 可是一旦我们知道这些函数包含其參数的详细含义,socket网络编程也就变得不是那么复杂. 这里不赘述 详细函数的详细含义.网络上有非常多的文章.同一时候笔者建议大家參考 MSDN.对返回值,參数等会有更好的理解. 下面均为单线程的简单实例,多线程的请关注下一篇文…
:::一些名词的解释::: 网络: 网络是辅助双方能够连接在一起的工具,使用网络的目的,为了联通多方然后进行通讯,能够让软件在不同的电脑上运行,相互传输数据. 网络协议: 约定俗成的,没有理由. TCP/IP协议: 互联网协议簇就是通用的协议标准.最重要的两个协议是TCP和IP协议,所以,大家把互联网的协议简称TCP/IP协议. 常用的网络协议如图: :::OSI七层模型::: 应用层与其它计算机进行通讯的一个应用,它是对应应用程序的通信服务的.例如,一个没有通信功能的字处理程序就不能执行通信的…
TCP/IP协议:数据链路层,网络层,传输层,应用层. IP地址分为5类:A类.B类.C类.D类.E类. (A类.B类.C类是基本类,D类多用于多播传送,E类为保留类.) "*"表示网络标识位. A类 0 * * * * * * * x x x x x x x x x x x x x x x x x x x x x x x B类 1 0 * * * * * * * * * * * * * x x x x x x x x x x x x x x x x C类 1 1 0 * * * *…
一.Timer和Timetask 通过Timer和Timetask,我们可以实现定时启动某个线程. java.util.Timer 在这种实现方式中,Timer类作用是类似闹钟的功能,也就是定时或者每隔一定时间触发一次线程.其实,Timer类本身实现的就是一个线程, 只是这个线程是用来实现调用其它线程的. java.util.TimerTask TimerTask类是一个抽象类,该类实现了Runnable接口,所以该类具备多线程的能力. 在这种实现方式中,通过继承TimerTask使该类获得多线…
一.静态代理 [代码示例] /*** * 静态代理:记录日志等,类是写好的,直接拿来用. 动态代理:随用随构建,临时抱佛脚 * 婚庆公司:代理角色,帮你搞婚庆的一切,布置房间等等 * 自己:真实角色,结婚是自己去结婚,不是婚庆公司去结婚 * * 结婚礼仪:代理相同的接口,不管谁搞流程是确定的 * */ package cn.sxt.thread; public class Test_0406_StaticProxy { public static void main(String[] args)…
建议 unpv13e/README看一下,忽略一下内容 ===================================================================== 操作进入uppv13e/ ./configure cd lib make cd ../libfree make cd ../liggai make cd .. vim lib/unp.h // 修改 #include "../config.h" 为 #include "config.…
tcp的十种状态 python使用原始套接字才可以做黑客攻击!!!!!伪造数据包!!!!!直接越过底层!socket这个东西是经过linux过滤过得! TTL  每经过一个路由器就减1 谁先调close  需要等msl   如果服务器先暂停 需要等2msl  也就大约5分钟 listen中的值得问题 arp攻击…
一.概念 1. 处于就绪状态的线程,会进入“就绪队列”等待JVM来挑选. 2. 线程的优先级用数字表示,范围从1到10,一个线程的缺省优先级是5. 3. 使用下列方法获得或设置线程对象的优先级. int getPriority(); void setPriority(int newPriority); 注意:优先级低只是意味着获得调度的概率低.并不是绝对先调用优先级高的线程后调用优先级低的线程. /**优先级低只是意味着获得调度的概率低.并不是绝对先调用优先级高的线程后调用优先级低的线程. *…
在ubuntu下 首先:在unpv13e文件加下 ./configure cd lib make cd ../libfree make cd ../liggai make cd .. vim lib/nup.h // 改动 #include "../config.h" 为 #include "config.h" / 拷贝头文件 sudo cp config.h /usr/local/include sudo cp lib/unp.h /usr/local/inclu…
死锁:指两个或两个以上的线程在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞的现象,若无外力作用,它们都将无法推进下去.此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等待的进程称为死锁进程. 此程序的两个线程会因为互相等待对方的互斥锁而陷入等待,最后由于主线程执行完毕而结束了各个子线程,从而程序结束. import threading import time class MyThread1(threading.Thread): def run(self): #对mutexA上锁…
Python多线程支持全局变量的共享操作,但是它存在很多问题,先来看以下程序,该程序理论上执行完毕后全局变量g_num的值应该是2000000,但是在实际运行中,结果不足理论值 import threading import time #定义一个全局变量 g_num=0 def test1(num): global g_num for i in range(num): g_num+=1 print("----in test1 g_num=%d----"%g_num) def test2…
变量作用域: 一般在函数体外定义的变量成为全局变量,在函数内部定义的变量称为局部变量.全局变量所有作用域都可用,局部变量只能在本函数可用,变量的使用顺序是,局部变量 > 全局变量, 也就是说:优先使用局部变量,那么问题来了, 如果想在函数内使用全局变量,或改变全局变量的值, 应该怎么做呢? global关键字: 为了解决函数内使用全局变量的问题,python增加了global关键字, 利用它的特性,可以指定变量的作用域.global关键字的作用:声明变量var是全局的 注意: 参考链接:…
import threading import time #继承形式的多线程,适合于程序比较复杂的情况 class MyThread(threading.Thread): #t.start()会调用run函数,所以必须有个run方法 #线程类内的其他方法除非run函数内部调用他们,否则不会被调用 def run(self): for i in range(3): time.sleep(1) msg="I'm "+self.name+' @ '+str(i) #name属性保存当前线程的…
#该程序使用命令行执行,IDE执行会有其他线程附加 import threading import time #初始化一个线程 #t=threading.Thread(target=func) #func为函数名 #创建启动线程 #t.start() #获取当前进程的所有线程 #threading.enumerate() #当前线程个数 #len(threading.enumerate()) def test1(): for i in range(5): print('-----test1---…
#单线程程序 import time def sing(): """唱歌5秒钟""" for i in range(5): print("-----正在唱:千里之外-----") time.sleep(1) def dance(): """跳舞5秒钟""" for i in range(5): print("-----正在跳舞-----") tim…
基本的架构有C/S架构 和B/S架构 B/S架构优于C/S架构? 因为统一入口 , 都是从浏览器开始访问 两台电脑实现通信, 需要网卡, 网卡上有全球唯一的mac地址 ARP协议 #通过ip地址就能找到对应的mac地址 多台电脑相连的问题: 交换机 如何通信: 广播:告诉所有人的过程---->广播 确定的电脑进行回复    ----> 单播 网关: 局域网的机器想要访问局域网之外的机器, 需要网关 #子网掩码和IP地址 判断两台电脑是否在同一个局域网内 #通过端口来找程序: #在计算机每一个网…