文档对smbus的单字,单字节,块读写,地址解析命令有详尽的介绍,给不熟悉smbus协议的朋友提供方便
2025/10/26 13:08:42 330KB smbus
1
JavaAgent技术的Demo,agentmain方式采用Javaassist技术实现字节码修改,VirtualMachine技术实现运行时代码织入
2025/10/20 10:56:50 265KB Java JavaAgent agentmian
1
基于Huffman编码树原理实现的压缩和解压缩小程序,编码单位为一字节。
2025/10/8 16:47:04 1.92MB C++ 哈夫曼 压缩 解压缩
1
两种加密模式:1.飙车模式输入的数字是即将加密的字节数,默认数值是110;
2.正常模式就是我们正常使用的流程了,输入密码,加密即可;
加密和解密使用的流程是一样的,按照加密的步骤再操作一次就是解密了。
这个是VB写的,如果提示缺少ocx或者dll,自行百度一下即可。
2025/10/4 3:42:33 35KB 急速 文件 加密
1
配送一个自己写的串口驱动程序用DMA接收数据接收完会产生一个空闲中断由此可判断接收完一个包的数据再配送一个我自己写的动态内存管理跟ESP8266的驱动在项目中测试460800的波特率30kb一秒的数据接收一包1024个字节每包需要应答15字节的情况下AT指令处理是使用多个缓冲级来处理模块发送过来的数据分别有模块应答缓冲级跟等待应答的缓冲级、被忽略的AT指令集的缓冲级(例如注册一个SENDOK\r\n则模块应答此条指令立刻清除缓冲级释放内存无需等待超时直接忽略)还有需要回调的缓冲级(则出现此指令调用回调函数)都是通过注册的方式来实现如果出现一包跟指令被分到一个包内AT处理函数一样可以搜索到AT指令使用strstr函数来实现函数的缓冲级都是指针不占用内存使用动态内存管理的方式有数据则创建内存放入数据作为一个缓冲级如果模块应答的数据在规定的时间内没有响应则删除此缓冲级函数前都有注释介绍下面介绍一些常用的函数:at_init初始化一些变量已经串口at_time_task使用定时器回调1毫秒回调一次用来计数超时的指令缓冲&等待超时的计数at_clear_all在模块开机的时候可能会有很多乱数据可以在初始化完毕后使用此函数清除所有缓冲级释放所有内存at_processing处理AT的应答超时的指令(做删除释放内存的动作),还有处理等待的AT指令此函数一定要不断循环处理可以加入到定时器目前我实验是在UCOS上的所以直接创建个任务来执行此函数当程序在等待某个AT指令的时候此函数会寻找接收的缓冲级是否有等待的AT指令at_cmd_cb_hand回调处理函数如果接收缓冲级出现某个已经注册的指令则回调注册时所填写的函数地址at_send_cmd发送一个AT指令可以用跟printf一样使用%d等等at_send_data发送数据的时候所使用需要填写长度at_cmd_ignore_register注册一个被忽略的AT指令带入参数*s(例如填写一个"SENDOK"则模块应答的此条指令直接被忽略释放内存被忽略之前会检查此缓冲级会不会带有别的AT指令需要回调的)at_cmd_ignore_cancel取消被忽略的指令则取消已经注册的被忽略的AT指令at_cmd_cb_registerAT指令的回调注册例如参数填写"+IPD",函数名a则出现+IPD的时候回调a函数a函数有类型在at.h文件里面有at_cmd_cb_cancel注销回调你懂得at_wait_cmd等待一个AT指令集或者超时则立刻返回等待途中会不断调用OS的延迟程序让系统能有时间去执行其他任务使用方法例如{at_send_cmd("AT+UART=%u,%u,%u,%u,%u\r\n",baudrate,databit,stopbit,parity,flow_control);return(esp_error)at_wait_cmd("\r\nOK\r\n",2000,NULL);}at_errorat_wait2_cmd(char*s,char*s2,u16timeout,u8*index)此函数是等待两个AT指令集如果出现一个则立刻返回返回值h文件有介绍AT_DONE则出现此条指令index参数则提取应答的缓冲首地址使用at_buf_get函数获取首地址使用完后要调用at_free_buf来清除并释放这个缓冲级at_buf_len_get查询此应答的缓冲级长度如果在index填写NULL则不需要缓冲级首地址直接清除释放缓冲级
1
在IT行业中,断点续传是一项非常实用的技术,特别是在大文件传输时,它允许用户中断传输后在同一个位置继续,避免了重新下载或上传整个文件的麻烦。
在本项目"**C#断点续传(windows服务版)**"中,我们将探讨如何使用C#语言和Socket编程来实现这一功能,特别是在Windows服务环境下。
我们要理解**C#**是一种面向对象的编程语言,广泛用于开发Windows桌面应用、Web应用和服务。
在C#中,我们可以利用.NETFramework提供的丰富的类库来实现各种功能,包括网络通信。
**Socket**是网络通信的基础,它提供了进程间的通信能力,允许数据在网络中发送和接收。
在C#中,`System.Net.Sockets`命名空间提供了Socket类,我们可以利用它创建TCP连接,实现断点续传。
断点续传的关键在于记录当前传输的状态,包括已传输的字节数、文件的总大小等信息。
在服务器端,我们需要保存这些状态,以便客户端在下次连接时能够获取。
在Windows服务中运行,这个程序可以持续监听特定端口,等待客户端的连接请求。
实现步骤如下:1.**创建服务端Socket**:在Windows服务中启动时,初始化一个Socket并绑定到特定IP地址和端口,然后开始监听。
2.**处理客户端连接**:当客户端请求连接时,服务端接受连接,并创建一个新的Socket与客户端进行通信。
3.**文件信息交换**:服务端与客户端先交换文件的元信息,如文件大小、已传输的字节数等,确定断点续传的起点。
4.**数据传输**:客户端根据已知的起始位置,向服务端请求剩余的数据。
服务端读取文件的剩余部分,通过Socket发送到客户端。
5.**错误处理和断点标记**:在整个传输过程中,需检测异常并记录当前位置,以便发生中断时恢复。
客户端和服务器端都需要有保存和恢复断点位置的能力。
6.**关闭连接**:传输完成后,双方关闭Socket连接。
在提供的代码示例中,`socket_backpointpost(service)`可能是服务端的实现文件,包含上述步骤的逻辑。
在阅读和学习代码时,注意以下关键点:-如何创建和配置Socket对象。
-如何使用`BeginAccept`或`AcceptAsync`异步方法来监听客户端连接。
-如何通过`FileStream`读写文件,并配合`Socket.Send`和`Socket.Receive`方法进行数据传输。
-如何处理错误,保存和恢复断点信息。
深入理解这些概念并实践编写代码,可以帮助你掌握C#和Socket实现断点续传的关键技术和技巧。
通过这种方式,你可以构建稳定且高效的文件传输系统,尤其适用于大文件和网络环境不稳定的场景。
2025/9/25 8:29:53 46KB 断点续传 socket
1
实验内容设计一个滑动窗口协议,在仿真环境下编程实现有噪音信道两站点间无差错双工通信信道模型8000bps全双工卫星信道单向传播时延270毫秒信道误码率为10-5物理层接口:提供帧传输服务,帧间有1ms帧边界网络层属性:分组长度固定256字节实现GoBackN协议
1
Java实现Des加密(不用加载包),有完整S盒子。
部分代码如下:ackagedesJava;importjava.util.*;publicclassDes{ byte[]bytekey; publicDes(StringstrKey){ this.bytekey=strKey.getBytes(); }//声明常量字节数组 privatestaticfinalint[]IP={58,50,42,34,26,18,10,2,60,52, 44,36,28,20,12,4,62,54,46,38,30,22,14,6,64,56,48, 40,32,24,16,8,57,49,41,33,25,17,9,1,59,51,43,35, 27,19,11,3,61,53,45,37,29,21,13,5,63,55,47,39,31, 23,15,7};//64 privatestaticfinalint[]IP_1={40,8,48,16,56,24,64,32,39,7, 47,15,55,23,63,31,38,6,46,14,54,22,62,30,37,5,45, 13,53,21,61,29,36,4,44,12,52,20,60,28,35,3,43,11, 51,19,59,27,34,2,42,10,50,18,58,26,33,1,41,9,49, 17,57,25};//64 privatestaticfinalint[]PC_1={57,49,41,33,25,17,9,1,58,50, 42,34,26,18,10,2,59,51,43,35,27,19,11,3,60,52,44, 36,63,55,47,39,31,23,15,7,62,54,46,38,30,22,14,6, 61,53,45,37,29,21,13,5,28,20,12,4};//56 privatestaticfinalint[]PC_2={14,17,11,24,1,5,3,28,15,6,21, 10,23,19,12,4,26,8,16,7,27,20,13,2,41,52,31,37,47, 55,30,40,51,45,33,48,44,49,39,56,34,53,46,42,50,36, 29,32};//48 privatestaticfinalint[]E={32,1,2,3,4,5,4,5,6,7,8,9,8,9, 10,11,12,13,12,13,14,15,16,17,16,17,18,19,20,21,20, 21,22,23,24,25,24,25,26,27,28,29,28,29,30,31,32,1};//48 privatestaticfinalint[]P={16,7,20,21,29,12,28,17,1,15,23, 26,5,18,31,10,2,8,24,14,32,27,3,9,19,13,30,6,22, 11,4,25};//32 privatestaticfinalint[][][]S_Box={//S-盒 {//S_Box[1] {14,4,13,1,2,15,11,8,3,10,6,12,5,9,0,7}, {0,15,7,4,14,2,13,1,10,6,12,11,9,5,3,8}, {4,1,14,8,13,6,2,11,15,12,9,7,3,10,5,0}, {15,12,8,2
2025/9/19 13:57:15 212KB java des
1
1-19长度为100字节的应用层数据交给传输层传送,需加上20字节的TCP首部。
再交给网络层传送,需加上20字节的IP首部。
最后交给数据链路层的以太网传送,加上首部和尾部工18字节。
试求数据的传输效率。
数据的传输效率是指发送的应用层数据除以所发送的总数据(即应用数据加上各种首部和尾部的额外开销)。
若应用层数据长度为1000字节,数据的传输效率是多少?解:(1)100/(100+20+20+18)=63.3%(2)1000/(1000+20+20+18)=94.5%2-16共有4个站进行码分多址通信。
4个站的码片序列为A:(-1-1-1+1+1-1+1+1)B:(-1-
2025/9/10 15:31:32 171KB 计算机网络
1
class字节码查看工具
2025/8/26 8:56:32 52.9MB class 反编译
1
共 399 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡