【API】网络编程模型、多线程
1、网络通信编程
1)网络通信模型基础知识
- TCP
Server:
WSAStartup()
socket()
bind()
linsten()
accept()
send/recv()
closesocket()
WSACleanup()
Client:
WSAStartup()
socket()
connect()
recv/send()
closesocket()
WSACleanup()
- UDP
客户端A
socket()
bind()
send()
recv()
close()
客户端B
bind()
recv()
send()
close()
2)网络模型
- WSAAsyncSelect模型
创建窗口(CreateWindows)/对话框然后为该窗口提供一个窗口回调函数(WinProc)/对话框函数。
通过调用WSAsyncSelect函数自动将套接字设置为非阻塞模式,并注册一个或多个感兴趣的网络事件。
- WSAEventSelect模型
WSAEventSelect模型是以事件的形式通知应用程序。
1)创建事件对象,注册网络事件 WSACreateSelect()/WSAEventSelect()
2)等待网络事件发生 WSAwaitForMultpleEvents()
3)获取网络事件 WSAWaitForMultipleEvents()
4)手动设置信号量和释放资源 WSAResetEvent()
- 完成端口模型
利用内核对象的调度,使用少量的几个线程来处理和客户端的所有通信,从而消除线程上下文切换问题。当有事件产生时CPU能保证有资源可用,然后将这些事件加入到一个公共消息队列中去,当前哪一个线程空闲就去处理公共消息队列里的事件,如果没有事件了,线程就空闲下来。
1)初始化套接字组件 WSASocket()
2)绑定和监听 bind()
3)创建完成端口 CreateIoCompletionPort()
4)创建服务线程 GetSystemInfo()
5)连接客户端 accept()
6)套接字与完成端口关联 CreateIoCompletionPort()
7)将套接字与完成端口关联起来以后,应用程序调用发送数据/接收数据函数完成重叠IO操作
WSASend()/WSASendTo()
WSARecv()/WSARecvFrom()
8)等待重叠I/O操作结果 GetQueuedCompletionStatus()
9)投递完成通知 PostQueuedCompletionStatus()
2、多线程
原子
某一个线程对于某一个资源做操作的时候能够保证没有其他的线程能够对此资源进行访问。
Interlockedxxxxx
缺点:只能解决某个变量的问题,只能使一个整型数据做简单算数运算的时候是原子的。
临界区
临界区是使用EnterCriticalSection与LeaveCriticalSection形成一个保护区来保护代码,这一对函数保证,多个保护区的代码,同一时刻只能有一个保护区的代码在执行。
EnterCriticalSection()
LeaveCriticalSection()
缺点:临界区是在一个进程内有效的,无法在多线程的环境下进行同步。
互斥体
一个线程进入临界区,结果因为线程由于某些原因崩溃了临界区无法被释放,那么其他线程也无法进入临界区,全部被卡住。互斥体可以解决这些问题。
1、互斥体有两个状态,激发态和非激发态
2、有一个概念,叫做线程拥有权与临界区类似。
3、等待函数等待互斥体的副作用,将互斥体的拥有者设置为本线程,将互斥体的状态设置为非激发态。
CreateMutex()
OpenMutex()
WaitForSingleObject()
信号量
信号量是一种同步机制,对于一个信号量来说,它可以被加上多把锁,当所有的锁孔都被锁上,才不允许其他线程访问被信号量锁住的区域。
CreateSemaphore()
OpenSemaphore()
ReleaseSemaphore()
CloseHandle()
事件
可以设置等待函数对于此事件对象有没有副作用,也可以手动设置事件对象为激发态还是非激发态
CreateEvent()
OpenEvent()
SetEvent()
ResetEvent()
PulseEvent()
CloseHandle()
- 小结:
原子操作:简单的同步机制,只能对4个字节的数据进行算数运算
临界区:对一段代码实现保护操作,只能在一个进程中的不同线程使用。无法检测由于线程崩溃造成的临界区无法释放的问题。
互斥体:是一个内核对象,可以在不同进程的线程中实现对于一段代码的保护。能够检测由于线程崩溃造成的互斥体释放问题。只能被拥有者线程释放,故而多线程间的不同回调函数的同步使用互斥体可能会造成问题。
信号量:是一个内核对象,没有拥有者的概念,可以控制多个线程同时访问被保护的代码,并且给线程数量设置一个上限。
事件:是一个内核对象,没有拥有者的概念,可以封装自己的同步机制。
【API】网络编程模型、多线程的更多相关文章
- Linux IO模型和网络编程模型
术语概念描述: IO有内存IO.网络IO和磁盘IO三种,通常我们说的IO指的是后两者. 阻塞和非阻塞,是函数/方法的实现方式,即在数据就绪之前是立刻返回还是等待. 以文件IO为例,一个IO读过程是文件 ...
- Java网络编程和NIO详解3:IO模型与Java网络编程模型
Java网络编程和NIO详解3:IO模型与Java网络编程模型 基本概念说明 用户空间与内核空间 现在操作系统都是采用虚拟存储器,那么对32位操作系统而言,它的寻址空间(虚拟存储空间)为4G(2的32 ...
- c/c++ 网络编程与多线程 编译参数
网络编程与多线程 编译参数 编译时要链接操作系统的pthread库 g++ -g socket01.cpp -std=c++11 -pthread 不加-pthread的话,出现下面的错误: term ...
- linux网络编程模型
1.编程模型 Linux网络编程模型是基于socket的编程模型
- TCP/IP网络编程之多线程服务端的实现(二)
线程存在的问题和临界区 上一章TCP/IP网络编程之多线程服务端的实现(一)的thread4.c中,我们发现多线程对同一变量进行加减,最后的结果居然不是我们预料之内的.其实,如果多执行几次程序,会发现 ...
- 网络编程之多线程——GIL全局解释器锁
网络编程之多线程--GIL全局解释器锁 一.引子 定义: In CPython, the global interpreter lock, or GIL, is a mutex that preven ...
- iOS网络编程模型
iOS网络编程层次结构也分为三层: Cocoa层:NSURL,Bonjour,Game Kit,WebKit Core Foundation层:基于 C 的 CFNetwork 和 CFNetServ ...
- Java API —— 网络编程
1.网络编程概述 1)网络编程概述 · 计算机网络 是指将地理位置不同的具有独立功能的多台计算机及其外部设备,通过通信线路连接起来,在网络操作系统,网络管理软件及网络通 ...
- [国嵌攻略][090][linux网络编程模型]
编程模型 Socket的实质就是一个接口,利用该接口,用户在使用不同的网络协议时,操作函数得以统一.而针对不同协议的差异性操作,则交给了Socket去自行解决. TCP编程模型 UDP编程模型
- 谈谈传统BIO网络编程模型的局限性与NIO
先来看看我们的server端: 创建一个serversocket,进行监听,每来一个客户端,就启动一个新启动为其服务: private void createListenSocket() { //如果 ...
随机推荐
- linux第十八章学习笔记
第十八章 调试 内核级开发的调试工作远比用户级开发艰难,它带来的风险比用户级别更高. 一.准备开始 1. 准备工作需要: 一个bug 一个藏匿bug的内核版本 相关内核代码的知识和运气 2. 在用户级 ...
- Log4Net使用指南之用log4net记录日志到数据库(含有自定义属性)------附Demo例子源代码
Log4NET简介 log4net库是Apache log4j框架在Microsoft .NET平台的实现,是一个帮助程序员将日志信息输出到各种目标(控制台.文件.数据库等)的工具. 前提 最近做项目 ...
- Caffe搭建:Ubuntu14.04 + CUDA7.0 + opencv3.0 + Matlab2014A
从Hinton在science上发表深度学习训练开创新的文章以来,深度学习火了整整有3年多,而且随着新的硬件和算法的提出,深度学习正在应用于越来越多的领域,发挥其算法的优势. 实验室并没有赶上第一波深 ...
- 深入理解es6的promise
一.promise入门 1. Promise对象是什么 回调函数的另一种原生实现,比之前回调函数的写法机构清晰,功能强大, 2.以前回调这么写 function a(fn){ let h = 1; s ...
- 51nod 1673 树有几多愁(链表维护树形DP+状压DP)
题意 lyk有一棵树,它想给这棵树重标号. 重标号后,这棵树的所有叶子节点的值为它到根的路径上的编号最小的点的编号. 这棵树的烦恼值为所有叶子节点的值的乘积. lyk想让这棵树的烦恼值最大,你只需输出 ...
- 想转C++了
暑假想学一学C++ 早退役了高考后才转C++的oier——我真是太蒻了
- CF 1070J Streets and Avenues in Berhattan
DP的数组f其实开得不够大,应该开200000,但是它在cf上就是过了... 题意是把一堆字母分别分配到行和列. 分析一下,答案实际上只和n行中和m列中每种字母分配的个数有关.而且答案只和" ...
- 【题解】 bzoj1190: [HNOI2007]梦幻岛宝珠 (动态规划)
bzoj1190,懒得复制,戳我戳我 Solution: 这道题其实是一个背包(分组背包),但是由于数字比较大,就要重新构造dp式子.啃了三天才懂. \(dp[i][j]\)表示背包容积为\(j*2^ ...
- 【poj2187】最远点对(勉强凑数)
题目简述 输入n个点,及其坐标,n<=50000,所有坐标都是不超过10000的整数组成,没有重点. 问最远点对间的距离的平方是多少 题解 这是一道旋转卡壳的裸题 我们要求这个多边形的直径,这可 ...
- Problem C: 多线程 解题报告
Problem C: 多线程 Description 多线程是一种常见的加速手段,利用多个线程同时处理不同的任务可以一定程度上减少总耗时,达到提高效率的目的.然而,多个线程间的执行顺序是完全不可控的, ...