c#实现轮询算法实例代码
轮询算法是最简单的一种负载均衡算法。它的原理是把来自用户的请求轮流分配给内部的服务器:从服务器1开始,直到服务器N,然后重新开始循环。下面小编为大家整理了c#实现轮询算法实例代码,希望能帮到大家!
CacheSlidingExpirationHour:时间,缓存时间2小时
CountdownCurrentIndexCacheName:缓存名称
log:日志
m_objCountdownCurrentIndexLock::当前对象
m_snIntervalSecond:定义一个数组,可以视为概率值
说明:0,1,1,1 数据中存了4个数,我们设为总的概率为100%,每个代表25%,所以现在我设置的是当前的概率为75%
存如缓存的是数据的索引,取的时候也取的'索引,方法返回索引,转成int类型
public class CountdownHelper { private const int CacheSlidingExpirationHour = 2; private const string CountdownCurrentIndexCacheName = "OnlineMeetingCountdownCurrentIndex"; private static IAppLog log = ogger(typeof(CountdownHelper)); private static Cache m_cache = e; private static object m_objCountdownCurrentIndexLock = new object(); private static int[] m_snIntervalSecond = new int[] { 0, 1 , 1 , 1}; //1显示 0不显示 public CountdownHelper() { } public int GetCountdownAddedSecond() { lock (m_objCountdownCurrentIndexLock) { int nCountdownCurrentIndex = 0; try { object objCountdownCurrentIndex = m_cache[CountdownCurrentIndexCacheName]; if (objCountdownCurrentIndex == null) { //如果需要加缓存的,就用下面的 //m_rt(CountdownCurrentIndexCacheName, 1, null, soluteExpiration, Hours(CacheSlidingExpirationHour), emovable, null); //不用加缓存的用下面的 m_rt(CountdownCurrentIndexCacheName, 1, null, soluteExpiration, idingExpiration, emovable, null); } else { nCountdownCurrentIndex = (int)objCountdownCurrentIndex; if (nCountdownCurrentIndex == m_th - 1) { m_cache[CountdownCurrentIndexCacheName] = 0; } else { m_cache[CountdownCurrentIndexCacheName] = nCountdownCurrentIndex + 1; } } return m_snIntervalSecond[nCountdownCurrentIndex]; } catch (Exception __error) { //如果需要记录错误日志的,可以记录到这里,我这里没有加 //r("功能介绍GetCountdownAddedSecond:" + __age); if (nCountdownCurrentIndex > m_th - 1) { nCountdownCurrentIndex = m_th - 1; } return m_snIntervalSecond[nCountdownCurrentIndex]; } } } }
这个功能的需求是:业务部门需要监控当前页面的曝光率,所以需要用概率去判断当前的曝光代码如何在页面上交替显示,起初是曝光率为50%,所以数组中直接就是new int[] { 0, 1},后来改成75%,就是上面的代码,所以这样既可以监控曝光,有可以控制曝光代码。
前台调用是用AJAX方式:
说明:等于1,将曝光代码添加到页面,否则不加
1
$("/Topic/GetCountdownAddedSecond", function (data) { if (data) { if ( == 1) { var img_html = "<img src="https://d_directed_treatment ="display:none;">"; $("#adver")(img_html); } } }, "json");
-
C语言指针的长度和类型讲解
对于初学者深入理解C语言程序设计有很好的参考价值,下面是小编为大家整理的C语言指针的长度和类型讲解,欢迎参考~一般来说,如果考虑应用程序的兼容性和可移植性,指针的长度就是一个问题,在大部分现代平台上,数据指针的长度通常是一样的,与指针类型无关,尽管C标准没有规...
-
C++ cin输入流详解
标准输入流是从标准输入设备(键盘)流向程序的数据。在头文件iostream.h中定义了cin、cout、cerr、clog4个流对象,cin是输入流,cout、cerr、clog是输出流。下面是小编为大家整理的C++cin输入流详解,欢迎参考~cin是istream类的对象,它从标准输入设备(键盘)获取数据,程...
-
Mac系统怎样使用终端编写c语言程序
C语言是目前较为普遍的程序语言,它功能丰富、表达能力强、使用灵活方便、目标程序效率高,适合编制一般应用软件。下面是应届毕业生小编收集整理的Mac系统怎样使用终端编写c语言程序,希望对大家有帮助~~Mac系统使用终端编写c语言程序的'方法工具/原料Mac系统,终...
-
内部排序之堆排序的实现
堆排序(HeapSort)只需要一个记录大小的辅助空间,每个待排序的记录仅占有一个存储空间。下面小编为大家整理了内部排序之堆排序的实现,希望能帮到大家!(1)基本概念a)堆:设有n个元素的序列:{k1,k2,...,kn}对所有的i=1,2,...,(int)(n/2),当满足下面关系:ki≤k2i,ki≤k2i+1或ki...