Delphi教程系列书籍(036)《Inside深入核心VCL架构剖析》网友(邦)整理EMail:shuaihj@163.com【Delphi系列书籍下载】(辛劳整理,大家珍惜!!!)http://blog.csdn.net/shuaihj/archive/2010/11/22/6036817.aspx
2021/5/17 11:49:45 4.91MB Delphi 教程 系列书籍 (036)
1
最近有项目要做一个高功能网络服务器,决定下功夫搞定完成端口(IOCP),最终花了一个星期终于把它弄清楚了,并用C++写了一个版本,效率很不错。
但,从项目的总体需求来考虑,最终决定上.net平台,因此又花了一天一夜弄出了一个C#版,在这与大家分享。
一些心得体会:1、在C#中,不用去面对完成端口的操作系统内核对象,Microsoft已经为我们提供了SocketAsyncEventArgs类,它封装了IOCP的使用。
请参考:http://msdn.microsoft.com/zh-cn/library/system.net.sockets.socketasynceventargs.aspx?cs-save-lang=1&cs-lang=cpp#code-snippet-1。
2、我的SocketAsyncEventArgsPool类使用List对象来存储对客户端来通信的SocketAsyncEventArgs对象,它相当于直接使用内核对象时的IoContext。
我这样设计比用堆栈来实现的好处理是,我可以在SocketAsyncEventArgsPool池中找到任何一个与服务器连接的客户,主动向它发信息。
而用堆栈来实现的话,要主动给客户发信息,则还要设计一个结构来存储已连接上服务器的客户。
3、对每一个客户端不管还发送还是接收,我使用同一个SocketAsyncEventArgs对象,对每一个客户端来说,通信是同步进行的,也就是说服务器高度保证同一个客户连接上要么在投递发送请求,并等待;
或者是在投递接收请求,等待中。
本例只做echo服务器,还未考虑由服务器主动向客户发送信息。
4、SocketAsyncEventArgs的UserToken被直接设定为被接受的客户端Socket。
5、没有使用BufferManager类,因为我在初始化时给每一个SocketAsyncEventArgsPool中的对象分配一个缓冲区,发送时使用Arrary.Copy来进行字符拷贝,不去改变缓冲区的位置,只改变使用的长度,因此在下次投递接收请求时恢复缓冲区长度就可以了!如果要主动给客户发信息的话,可以new一个SocketAsyncEventArgs对象,或者在初始化中建立几个来专门用于主动发送信息,因为这种需求一般是进行信息群发,建立一个对象可以用于很多次信息发送,总体来看,这种花销不大,还减去了字符拷贝和消耗。
6、测试结果:(在我的笔记本上时行的,我的本本是T420I78G内存)100客户100,000(十万次)不间断的发送接收数据(发送和接收之间没有Sleep,就一个一循环,不断的发送与接收)耗时3004.6325秒完成总共10,000,000一千万次访问平均每分完成199,691.6次发送与接收平均每秒完成3,328.2次发送与接收整个运行过程中,内存消耗在开始两三分种后就保持稳定不再增涨。
看了一下对每个客户端的延迟最多不超过2秒。
2020/5/13 2:27:34 15KB IOCP 完成端口 源码
1
使用wkhtmltopdf插件html转pdfdemo(采用的方案)使用itextsharp插件html转pdf(参考)代码在Default.aspx可参考文章https://blog.csdn.net/qq_36535245/article/details/89018586进行处理,有问题可以评论询问
2021/5/17 12:50:46 41.61MB 转PDF 插件 c#
1
具体内容请参考我的BLOG:http://blog.csdn.net/smallwhiteyt/archive/2009/11/08/4784771.aspx如果你耐心仔细看完本文,相信以后再遇到导出EXCLE操作的时候你会很顺手觉得SOEASY,主要给新手朋友们看的,老鸟可以直接飘过了,花了一晚上的时间写的很辛苦,如果觉得对你有协助烦请留言支持一下,我会写更多基础的原创内容来回报大家。
C#导出数据到EXCEL表格是个老生常谈的问题了,写这篇文章主要是给和我一样的新手朋友提供两种导出EXCEL的方法并探讨一下导出的效率问题,本文中的代码直接就可用,其中部分代码参考其他的代码并做了修改,抛砖引玉,希望大家一起探讨,如有不对的地方还请大家多多包涵并指出来,我也是个新手,出错也是难免的。
首先先总结下自己知道的导出EXCEL表格的方法,大致有以下几种,有疏漏的请大家补充。
1.数据逐条逐条的写入EXCEL2.通过OLEDB把EXCEL做为数据源来写3.通过RANGE范围写入多行多列内存数据到EXCEL4.利用系统剪贴板写入EXCEL好了,我想这些方法已经足够完成我们要实现的功能了,方法不在多,在精,不是么?以上4中方法都可以实现导出EXCEL,方法1为最基础的方法,意思就是效率可能不是太高,当遇到数据量过大时所要付出的时间也是巨大的,后面3种方法都是第一种的衍生,在第一种方法效率低下的基础上改进的,这里主要就是一个效率问题了,当然如果你数据量都很小,我想4种方法就代码量和复杂程度来说第1种基本方法就可以了,或当你的硬件非常牛逼了,那再差的方法也可以高效的完成也没有探讨的实际意义了,呵呵说远了,本文主要是在不考虑硬件或同等硬件条件下单从软件角度出发探讨较好的解决方案。
2015/5/19 22:35:54 561KB C# EXCEL 导出 方法
1
代码说明:该示例使用简单,完成插入指定数量的数据,ajax写入数据库,并显示精准进度,实时前往运行过程。
对于大量插入数据库的操作,可以做到无刷,不超时;
目录结构:Css/style.css-------------进度条样式Js/ProcessBar.js----------Ajax方法以及设置进度条方法Default.htm---------------本示例ProcessExecute.aspx-------后台执行插入数据库文件演示:http://www.px915.com/Demo_ProcessBar/
2015/7/24 18:26:06 18KB ajax 进度条 大任务 批量
1
【版本已更新:http://download.csdn.net/source/1687395】半成品,还有以下几部分未完成:1、断点续传;
(方法都在,代码没调好,就先注释掉了)(就是保存当前下载信息,下次重新读取,最简单的做法就是序列化,要用到的自己改改调调就成)2、自定义下载窗体;
(就像MessageBox.Show()一样,已经做了一个简单的Form)3、部分细节没做好,可能存在BUG;
(用着,遇到再说)涉及的一些应用:多线程--没用线程池,因为不好控制状态;
事件驱动--自我感觉不是很好,最好谁能改改;
另外,组件的封装也没仔细整理过~期待有人能做个完美的组件。
应用范围:文件下载、在线升级(这个组件就是为了下载升级文件而做的……)使用示例:(添加DLL引用)ListDTaskList=newList();foreach(……){DownloadMag.DTaskdt=newDTask();dt.Name="任务名";dt.FileName="文件名";dt.Size=文件大小;dt.URL="下载地址";dt.CRC32=CRC32校验值;dt.SaveMode=true;DTaskList.Add(dt);}newDownloadMag.DownloadForm(this).Show(DTaskList.ToArray(),"下载信息文件名");没时间修修改改,所以把这个半成品放出来了,也就当时抛砖引玉吧。
谁有兴味有空闲就提提意见,找找Bug,最好是把它做完美了:)意见请提到:http://blog.csdn.net/0xff/archive/2007/11/01/1861780.aspx
1
1:调用.NET2.0的MAKECERT创建含有私钥的数字证书,并存储到个人证书区;
2:将该证书导出为pfx文件,并为其指定一个用来打开pfx文件的password;
3:读取pfx文件,导出pfx中公钥和私钥;
4:用pfx证书中的公钥进行数据的加密,用私钥进行数据的解密;
详细请看:http://blog.csdn.net/luminji/archive/2009/03/05/3960308.aspx
2018/8/20 1:25:27 58KB 数字证书 pfx cert rsa
1
详细介绍见链接(有界面详细截图)http://blog.csdn.net/zhaohuihua/archive/2010/05/23/5617640.aspx自己写的一个Java版俄罗斯方块程序界面做的中规中矩,每种形状颜色都不相同程序控制还可以,没什么大的Bug消磨时间的时候可以Down下来玩玩也做了不少菜单选项可自定义控制键,可设置单色彩色显示,可设置网格能否显示网格关卡有三组选择:标准关卡:难度中等,7种基本形状,共分2级,50000分一级,速度递增,下落一格的速度每2000分减少10毫秒速度关卡:难度较大,7种基本形状,共分10级,10000分一级,速度快且随着分数的增加而递增复杂性关卡:难度较大,共分10级,8000分一级,随着级别越高复杂度越来越大,会出现随机填充的障碍物,以及难以应付的复杂形状,到第4级以后会出现16种基本形状
2015/1/5 21:44:53 437KB Java Swing 俄罗斯方块 源码
1
VB.NET结合ACCESS数据库编写的ASPX网上报名零碎,方便初学者学习!
2017/4/24 1:17:48 54KB ASP.net
1
使用GDAL1.10正式版本编译,编译环境VS2008SP1内部将FileGDB、HDF4、HDF5、GEOS、PROJ4、ECW、Jpg2000、libexpt、libcurl、libiconv、netcdf、xerces_c、sqlite3等常用的库全部编译进去语言C\C++、C#、Java、Python含有协助文档如果程序不能执行,或者提示0xc1000052错误,请到这里下载VS2008SP1的运行库,地址为:http://www.microsoft.com/zh-CN/download/details.aspx?id=5582
2015/10/14 16:40:38 13.59MB GDAL1.10 FileGDB Jp2 ECW
1
共 132 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡