消息系统设计------Part1

本文介绍了一种使用AJAX轮询技术优化服务器请求的方法,通过记录最后请求时间减少不必要的服务器负载,适用于需要实时更新数据的应用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

像交友网那样,只要有人看了你的个人资料,就一个窗口实时提醒你, 效果的确不错,最近公司要做类似的功能, 本人先从前端入手,用AJAX轮循的方式去请求服务器,后来发现开N个页面,服务端就有N个请求,后来考虑先在客户端储存第一次从服务器发出请求前的时间,和最后一次从服务器请求返回后的时间,通过时间来判断是否要发出AJAX请求到服务器,

    客户端储存数据有三种方式 cookies,user-data,sessionStorage     如果要用后两者建议去看看http://www.jstorage.info/  专门有人写好的JS,支持性不错。

大家可以去查查资料,看看这几种的区别 

    本人采人第一种  cookies来储存

View Code

 
$(document).ready(function () {
    GetData();

});
function GetData() {
    var time = $.cookie("lsg");
    if (time == null) {
        time = new Date();
        $.cookie("lsg", time, { path: "/" });
    }
    var difference = (new Date()).getTime() - (new Date(Date.parse(time))).getTime();
    var thisSecond = Math.floor(difference / (1000)); //获取秒
    var requestTime = 60;//请求时间间隔 单位秒
    if (thisSecond > requestTime) {
        time = new Date();
        $.cookie("lsg", time, { path: "/" });//请求前
        console.log('从服务器取一次数据' + time.toString());
        time = new Date();
        $.cookie("lsg", time, { path: "/" }); //请求后
        setTimeout(GetData, requestTime * 1000);
    }
    else {
        setTimeout(GetData, 1000);
    }
    

  

 View Code

 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title></title>
    <script type="text/javascript" src="http://code.jquery.com/jquery-1.6.1.min.js"></script>
    <script src="jquery.cookie.js" type="text/javascript"></script>
    <script type="text/javascript" src="Singleton.js"></script>
</head>
<body>

</body>
</html

      这样就能确保所有引用页在规定的时间内,对服务器请求一次。有什么不足的地方还求大家指正

转载于:https://www.cnblogs.com/shenggen/archive/2012/03/12/2391881.html

******************* 实践教学 ******************* 理工大学 计算机与通信学院 2011年春季学期 C程序设计 课程设计 题 目: 专业班级: 姓 名: 学 号: 指导教师: 成 绩:__________________ 摘 要 在车辆销售管理当中,人工统计的速度慢,并且容易出现差错。本车辆销售管理系统的自动化加速了统计工作,提高管理效率。本程序主要采用对输入的相关信息进行自动分析,然后按组分类将数据保存到数组,这样的结构化非常便于程序后续的统计工作。统计具体过程涉及到车辆进价售价及利润排序等问题,将于正文中详细介绍。本程序实现了所有设计要求。 关键词:文件;排序;统计;C语言 目 录 一、需求分析 1 二、总体设计 2 三、详细设计 3 3.1 详细设计思路 3 3.2 算法流程图 3 四、编码 7 五、测试 8 六、设计总结 12 参考文献 13 致谢 14 附录 15 一、需求分析 本程序将用到文件系统,list.txt文件内容作为数据源,其中单行内容代表一张纸条。程序运行后首先将文件系统的原始数据读取并保存到程序的结构体数组当中,所以应提供文件输入的操作;由于纸条数据零散,所以要对原始数据进行分类操作并提供一个数组用于保存分类信息;在程序中要进行统计工作,所以要提供显示、排序等操作;另外应提供键盘式选择菜单实现功能选择。 二、总体设计 图1 车辆销售管理系统功能模块图 三、详细设计 3.1 详细设计思路 1.main()主函数 设置了程序的流程,结束程序。 2.select ( ) 选择函数 选择所想运行的各个函数. 3.functionscan ( ) 输入函数输入便条的数据. 4.function1 ( ) 文件的数据输入函数多次输入数据 5. function2 ( ) 统计函数每种汽车销售量以及销售额的统计 6. functionpaixu2 ( )总额排序函数按销售额对汽车进行排序 7. function4() 总额统计函数统计每种汽车的总额 8. function5() 统计报表函数统计商品总额 9. function6() 清空文件函数 清空文件数据 3.2 算法流程图 3.2.1保存函数Save()的算法流程图如图2所示。 图2 保存函数Save()的算法流程图 3.2.2输入函数input()的算法流程图如图3所示。 图3 输入函数的算法流程图 3.2.3 输出汽车信息 图4 输出汽车信息 四、编码 原始数据有汽车编码,车名,进价,售价,销售数量。年所以定义一个全局结构体数组scrip用于保存原始数据。然后定义全局变量n保存纸条数目,定义数组s用于保存分类后的信息。源代码见附录 五、测试 1输入新数据测试如图5所示 图5 输入新数据测试 2按车名查找数据测试如图6所示 图6按车名查找数据测试 3按编号查找数据测试如图7所示 图7 按编号查找数据测试 4按车辆名称删除数据测试如图8所示 图8车辆名称删除数据测试 5列出所有数据测试如图9所示 图9列出所有数据测试 6统计各产品的收益和总收益测试如图10所示 图10统计各产品的收益和总收益测试 7按车辆销售额的大小排序并输出排序后结果测试如图11所示 图11按车辆销售额的大小排序并输出排序后结果测试 六、设计总结 通过这次C程序设计,我掌握了模块化设计方法,能够深入的理解结构化程序设计思想,熟练运用结构化程序设计方法,提高了运用C语言进行程序设计的能力。 回顾起这次课程设计,至今我仍感慨颇多,的确,自从拿到题目到完成整个编程,从理论到实践,在整整一个星期的日子里,可以学到很多的东西。同时不仅可以巩固了以前所学到的知识,而且学到了很多在书本上所没有学到过的知识,通过这次课程设计使我懂得了理论与实际相结合是很重要的。只有理论知识是远远不够的,只有把所学的理论知识与实际相结合起来,从理论中得出结论。才能真正为社会服务,从而提高自己的实际动手能力和独立思考的能力。在设计的过程中遇到问题,通过同学的帮助,逐渐克服各种问题,并且从中学习到了很多的东西。通过这次编程。我发现了很多的不足。让我了解到自身的问题。让我不断的进步。 参考文献 1 C/C++程序设计,王连相等,中国科学技术出版社,2004 2 C语言程序设计,谭浩强,清华大学出版社,1999 3 C程序设计题解与上机指导,谭浩强,清华大学出版社,1999 4 C语言实用程序荟萃,西安电子科技大学出版社,1993 5 C语言函数手册,机械工业出版社,1999 6 C语言的实际应用,安徽科学技术出版社,2000 致谢 首先感谢我们的C程序老师让我学会了很多有关于C程序的知识。让我认识到C程序的重要性。再感谢我们周老师对我们做这次课设的支持与帮助。没有她的帮助,我们很难完美的完成这次课设。最后谢谢我的搭档康绿玉同学帮我攻克了许多难关,康绿玉同学给了我很大的鼓励。 附录 #include "stdio.h" #include "string.h" #include #define N 30 //struct car/*定义车辆信息结构体*/ #define N 30 struct car/*定义车辆信息结构体*/ { int number;/*车辆编号*/ char name[10];/*车辆名称*/ int inprice;/*进价*/ int outprice;/*售价*/ int quantity;/*车辆数量*/ }car[N];/*结构体数组*/ void welcome()/*欢迎界面*/ { printf(" ^^^^^^^ ^^^^^^^\n"); printf(" --------------------welcome--------------------\n"); printf(" #* *#\n"); printf(" #* 销售管理系统 *#\n");/*销售管理系统*/ printf(" #* *#\n"); printf(" ---------=====!what do you want to do!=====---------\n"); printf("\n"); printf(" **~~ 1 输入新数据 ~~**\n");/*输入一组新数据*/ printf(" **~~ 2 插入数据 ~~**\n");/*插入一组新数据*/ printf(" **~~ 3 按车辆名称查找数据 ~~**\n");/*按车辆名称查找数据*/ printf(" **~~ 4 按车辆编号查找数据 ~~**\n");/*按车辆编号查找数据*/ printf(" **~~ 5 按车辆名称查找并删除数据 ~~**\n");/*按车辆名称查找并删除数据*/ printf(" **~~ 6 列出所有数据 ~~**\n");/*列出所有数据*/ printf(" **~~ 7 统计各产品的收益及总收益 ~~**\n");/*统计各产品的收益及总收益*/ printf(" **~~ 8 按车辆销售额从小到大排序并输出排序前后的结果 ~~**\n");/*按车辆销售额从小到大排序并输出排序前后的结果*/ printf("\n"); printf(" ----------------\n"); printf("\n"); printf("please input you choice(A number between 1 and 8):\n"); } void input1(int i)/*输入单组数据*/ { printf("请输入车辆数据:\n");/*输入数据*/ printf("请输入车辆编号:\n");/*输入车辆编号*/ scanf("%d",&car[i].number); printf("请输入车名:\n");/*输入车辆名称*/ scanf("%s",&car[i].name); printf("请输入车辆进价:\n");/*输入车辆进价*/ scanf("%d",&car[i].inprice); printf("请输入车辆售价:\n");/*输入车辆售价*/ scanf("%d",&car[i].outprice); printf("请输入车辆数量:\n");/*输入车辆数量*/ scanf("%d",&car[i].quantity); } void input()/*连续输入多组数据*/ { int i,m=0; char x; for(i=0;i<N;i++) if(strlen(car[i].name)!=0)/*计算已有的数据个数*/ m++; for(i=m;i<N-1;i++) { input1(i); x=getchar(); if(x=='y') continue;/*继续输入*/ else break;/*中断输入*/ } } int insert()/*添加一组新数据*/ { int i,m=0; for(i=0;i<N;i++) if(strlen(car[i].name)!=0)/*计算已有的数据个数*/ m++; input1(m);/*输入此数据*/ return 0; } void search_name()/*按车名查找*/ { char name[20]; int i,flag=0; printf("输入要查找的车辆的品名:");/*输入要查找的车辆的品名*/ scanf("%s",&name); for(i=0;i<N;i++) if(strcmp(car[i].name,name)==0)/*校验品名*/ { printf("the information of this name:\n"); printf("Number: %d\nName: %s\nInprice: %d\nOutprice: %d\nQuantity: %d\n",car[i].number,car[i].name,car[i].inprice,car[i].outprice,car[i].number);/*输出要查找的数据的编号、车名、进价、售价、数量*/ flag=1; } if(flag==0) printf("The name is not exist !\n");/*所输入的车名不存在*/ } Delete()/*通过车名查找并删除数据*/ { char n[10]; int i,j,b=0,m=0; for(i=0;i<N;i++) if(strlen(car[i].name)!=0)/*计算已有的数据个数*/ m++; printf("输入要删除的数据的名称");/*输入要删除的数据的名称*/ scanf("%s",&n); for(i=0;i<m;i++) if(strcmp(car[i].name,n)==0)/*校验名称*/ { for(j=i;j<=m;j++) car[j]=car[j+1]; b=1; } if(b==0) printf("没有要找的数据!\n");/*没有要找的数据*/ if(b==1) printf("成功删除数据!\n");/*成功删除数据*/ } void search_number()/*按车辆编号查找*/ { int number,i,flag=0; printf("请输入要查找的车辆编号:");/*输入要查找的车辆的编号*/ scanf("%d",&number); for(i=0;i<N;i++) if(car[i].number==number)/*校验车辆编号*/ { printf("the information of this number:\n"); printf("Number: %d\nName: %s\nInprice: %d\nOutprice: %d\nQuantity: %d\n",car[i].number,car[i].name,car[i].inprice,car[i].outprice,car[i].number);/*输出要查找的数据的编号、车名、进价、售价、数量*/ flag=1; } if(flag==0) printf("所暑促的编号不存在 !\n");/*所输入的编号不存在*/ } void profit()/*统计各车辆的收益及总收益的函数*/ { int p[N],pr=0,i,m=0; for(i=0;i<N;i++) if(strlen(car[i].name)!=0)/*计算已有的数据个数*/ m++; for(i=0;i<m;i++) { p[i]=(car[i].outprice-car[i].inprice)*car[i].quantity;/*计算车辆i的收益*/ pr=pr+p[i];/*计算总收益*/ printf("Name: %-7s\tNumber: %-7d\tprofit: %-10d\n",car[i].name,car[i].number,p[i]);/*输出车辆i的收益*/ } printf("Total Profit: %d\n",pr);/*输出总收益*/ } void sort()/*按销售额排序*/ { int i,j,t,s,m=0,b[N],a[N]; for(i=0;i<N;i++) if(strlen(car[i].name)!=0)/*计算已有的数据个数*/ m++; for(i=0;i<m;i++) { b[i]=car[i].outprice*car[i].quantity;/*将车辆销售额放入数组b[i]*/ a[i]=car[i].number;/*将车辆编号放入数组a[i]*/ } printf("Before sorted:\n"); for(i=0;i<m;i++) /*输出排序前的结果,编号和销售额*/ printf("Number: %-5d\tSale: %-10d\n",a[i],b[i]); for(i=1;i<m;i++) for(j=0;jb[j+1]) { t=b[j]; b[j]=b[j+1]; b[j+1]=t; /*冒泡法排序*/ s=a[j]; a[j]=a[j+1]; a[j+1]=s; } printf("After sorted:\n"); /*输出排序后的结果,编号和销售额*/ for(i=0;i<m;i++) printf("Number: %-5d\tSale: %-10d\n",a[i],b[i]); } void output()/*输出全部数据*/ { int i,m=0; for(i=0;i<N;i++) if(strlen(car[i].name)!=0)/*计算已有的数据个数*/ m++; printf("Disply all the data below:\n"); for(i=0;i<m;i++) { printf("The number: %d\n",car[i].number);/*输出车辆编号*/ printf("The name: %s\n",car[i].name);/*输出车辆名称*/ printf("The inprice: %d\n",car[i].inprice);/*输出车辆进价*/ printf("The outprice: %d\n",car[i].outprice);/*输出车辆售价*/ printf("The quantity: %d\n",car[i].quantity);/*输出车辆数量*/ printf("\n"); } } main()/*主函数*/ { int c; welcome(); while(1) { scanf("%d",&c);/*输入选择项*/ switch(c) { case 0:welcome();break;/*清屏并显示欢迎界面*/ case 1:input();printf("输入数据并提示输入0以返回欢迎界面查看选项!\n");break;/*输入数据并提示输入0以返回欢迎界面查看选项*/ case 2:insert();printf("添加一组新数据并提示输入0以返回欢迎界面查看选项!\n");break;/*添加一组新数据并提示输入0以返回欢迎界面查看选项*/ case 3:search_name();printf("按车名查找并提示输入0以返回欢迎界面查看选项!\n");break;/*按车名查找并提示输入0以返回欢迎界面查看选项*/ case 4:search_number();printf("按车辆编号查找并提示输入0以返回欢迎界面查看选项!\n");break;/*按车辆编号查找并提示输入0以返回欢迎界面查看选项*/ case 5:Delete();printf("按车名查找并删除数据并提示输入0以返回欢迎界面查看选项\n");break;/*按车名查找并删除数据并提示输入0以返回欢迎界面查看选项*/ case 6:output();printf("输出全部数据并提示输入0以返回欢迎界面查看选项\n");break;/*输出全部数据并提示输入0以返回欢迎界面查看选项*/ case 7:profit();printf("统计各车辆的收益及总收益并提示输入0以返回欢迎界面查看选项\n");break;/*统计各车辆的收益及总收益并提示输入0以返回欢迎界面查看选项*/ case 8:sort();printf("按销售额从小到大排序并提示输入0以返回欢迎界面查看选项!\n");break;/*按销售额从小到大排序并提示输入0以返回欢迎界面查看选项*/ } } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值