亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? policy.c

?? linux下BT軟件的源碼。源代碼可以使用命令“make”進行編譯
?? C
?? 第 1 頁 / 共 2 頁
字號:
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include "parse_metafile.h"
#include "peer.h"
#include "data.h"
#include "message.h"
#include "policy.h"

Unchoke_peers  unchoke_peers;
long long      total_down = 0L, total_up = 0L;
float          total_down_rate = 0.0F, total_up_rate = 0.0F;
int            total_peers = 0;

extern int	   end_mode;
extern Bitmap  *bitmap;
extern Peer    *peer_head;
extern int     pieces_length;
extern int     piece_length;

extern Btcache *btcache_head;
extern int     last_piece_index;
extern int     last_piece_count;
extern int     last_slice_len;
extern int     download_piece_num;

// 初始化全局變量unchoke_peers
void init_unchoke_peers()
{
	int i;

	for(i = 0; i < UNCHOKE_COUNT; i++) {
		*(unchoke_peers.unchkpeer + i) = NULL;		
	}

	unchoke_peers.count = 0;
	unchoke_peers.optunchkpeer = NULL;
}

// 判斷一個peer是否已經存在于unchoke_peers
int is_in_unchoke_peers(Peer *node)
{
	int i;

	for(i = 0; i < unchoke_peers.count; i++) {
		if( node == (unchoke_peers.unchkpeer)[i] )  return 1;
	}

	return 0;
}

// 從unchoke_peers中獲取下載速度最慢的peer的索引
int get_last_index(Peer **array,int len)
{
	int i, j = -1;

	if(len <= 0) return j;
	else j = 0;

	for(i = 0; i < len; i++)
		if( array[i]->down_rate < array[j]->down_rate )  j = i;

	return j;
}

// 找出當前下載速度最快的4個peer,將其unchoke
int select_unchoke_peer()
{
	Peer*  p;
	Peer*  now_fast[UNCHOKE_COUNT];
	Peer*  force_choke[UNCHOKE_COUNT];
	int    unchoke_socket[UNCHOKE_COUNT], choke_socket[UNCHOKE_COUNT];
	int    i, j, index = 0, len = UNCHOKE_COUNT;

	for(i = 0; i < len; i++) {
		now_fast[i]       = NULL;
		force_choke[i]    = NULL;
		unchoke_socket[i] = -1;
		choke_socket[i]   = -1;
	}

	// 將那些在過去10秒已斷開連接而又處于unchoke隊列中的peer清除出unchoke隊列
	for(i = 0, j = 0; i < unchoke_peers.count; i++) {
		p = peer_head;
		while(p != NULL) {
			if(p == unchoke_peers.unchkpeer[i])  break;
			p = p->next;
		}
		if(p == NULL)  { unchoke_peers.unchkpeer[i] = NULL; j++; }
	}
	if(j != 0) {
		unchoke_peers.count = unchoke_peers.count - j;
		for(i = 0, j = 0; i < len; i++) {
			if(unchoke_peers.unchkpeer[i] != NULL) {
				force_choke[j] = unchoke_peers.unchkpeer[i];
				j++;
			}
		}
		for(i = 0; i < len; i++) {
			unchoke_peers.unchkpeer[i] = force_choke[i];
			force_choke[i] = NULL;
		}
	}

	// 將那些在過去10秒上傳速度超過20KB/S而下載速度過小的peer強行阻塞
	// 注意:up_rate和down_rate的單位是B/S而不是KB/S
	for(i = 0, j = -1; i < unchoke_peers.count; i++) {
		if( (unchoke_peers.unchkpeer)[i]->up_rate > 50*1024 &&
			(unchoke_peers.unchkpeer)[i]->down_rate < 0.1*1024 ) {
			j++;
			force_choke[j] = unchoke_peers.unchkpeer[i];
		}
	}

	// 從當前所有Peer中選出下載速度最快的四個peer
	p = peer_head;
	while(p != NULL) {
		if(p->state==DATA && is_interested(bitmap,&(p->bitmap)) && is_seed(p)!=1) {
			// p不應該在force_choke數組中
			for(i = 0; i < len; i++) {
				if(p == force_choke[i]) break;
			}
			if(i == len) {
				if( index < UNCHOKE_COUNT ) {
					now_fast[index] = p; 
					index++; 
				} else {
					j = get_last_index(now_fast,UNCHOKE_COUNT);
					if(p->down_rate >= now_fast[j]->down_rate) now_fast[j] = p;
				}
			}
		}
		p = p->next;
	}

	// 假設now_fast中所有的peer都是要unchoke的
	for(i = 0; i < index; i++) {
		Peer*  q = now_fast[i];
		unchoke_socket[i] = q->socket;
	}

	// 假設unchoke_peers.unchkpeer中所有peer都是choke的
	for(i = 0; i < unchoke_peers.count; i++) {
		Peer*  q = (unchoke_peers.unchkpeer)[i];
		choke_socket[i] = q->socket;
	}

	// 如果now_fast某個元素已經存在于unchoke_peers.unchkpeer
	// 則沒有必要進行choke或unckoke
	for(i = 0; i < index; i++) {
		if( is_in_unchoke_peers(now_fast[i]) == 1) {
			for(j = 0; j < len; j++) {
				Peer*  q = now_fast[i];
				if(q->socket == unchoke_socket[i])  unchoke_socket[i] = -1;
				if(q->socket == choke_socket[i])    choke_socket[i]   = -1;
			}
		}
	}

	// 更新當前unchoke的peer
	for(i = 0; i < index; i++) {
		(unchoke_peers.unchkpeer)[i] = now_fast[i];
	}
	unchoke_peers.count = index;

	// 狀態變化后,要對peer的狀態值重新賦值,并且創建choke、unchoke消息
	p = peer_head;
	while(p != NULL) {
		for(i = 0; i < len; i++) {
			if(unchoke_socket[i]==p->socket && unchoke_socket[i]!=-1) {
				p->am_choking = 0;
				create_chock_interested_msg(1,p);
			}
			if(choke_socket[i]==p->socket && unchoke_socket[i]!=-1) {
				p->am_choking = 1;
				cancel_requested_list(p);
				create_chock_interested_msg(0,p);
			}
		}
		p = p->next;
	}

	//for(i = 0; i < unchoke_peers.count; i++)
	//	printf("unchoke peer:%s \n",(unchoke_peers.unchkpeer)[i]->ip);

	return 0;
}

// 假設要下載的文件共有100個piece
// 以下函數的功能是將0到99這100個數的順序以隨機的方式打亂
// 從而得到一個隨機的數組,該數組以隨機的方式存儲0~99,供片斷選擇算法使用
int *rand_num = NULL;
int get_rand_numbers(int length)
{
	int i, index, piece_count, *temp_num;
	
	if(length == 0)  return -1;
	piece_count = length;
	
	rand_num = (int *)malloc(piece_count * sizeof(int));
	if(rand_num == NULL)    return -1;
	
	temp_num = (int *)malloc(piece_count * sizeof(int));
	if(temp_num == NULL)    return -1;
	for(i = 0; i < piece_count; i++)  temp_num[i] = i;
	
	srand(time(NULL));
	for(i = 0; i < piece_count; i++) {
        index = (int)( (float)(piece_count-i) * rand() / (RAND_MAX+1.0) );
		rand_num[i] = temp_num[index];
        temp_num[index] = temp_num[piece_count-1-i];
    }
	
	if(temp_num != NULL)  free(temp_num);
	return 0;
}

// 從peer隊列中選擇一個優化非阻塞peer
int select_optunchoke_peer()
{
	int   count = 0, index, i = 0, j, ret;
	Peer  *p = peer_head; 

	// 獲取peer隊列中peer的總數
	while(p != NULL) {
		count++;
		p =  p->next;
	}

	// 如果peer總數太少(小于等于4),則沒有必要選擇優化非阻塞peer
	if(count <= UNCHOKE_COUNT)  return 0;

	ret = get_rand_numbers(count);
	if(ret < 0) {
		printf("%s:%d get rand numbers error\n",__FILE__,__LINE__);
		return -1;
	}
	while(i < count) {
		// 隨機選擇一個數,該數在0~count-1之間
		index = rand_num[i];

		p = peer_head;
		j = 0;
		while(j < index && p != NULL) {
			p = p->next;
			j++;
		}

		if( is_in_unchoke_peers(p) != 1 && is_seed(p) != 1 && p->state == DATA &&
			p != unchoke_peers.optunchkpeer && is_interested(bitmap,&(p->bitmap)) ) {
		
			if( (unchoke_peers.optunchkpeer) != NULL ) {
				Peer  *temp = peer_head;
				while( temp != NULL ) {
					if(temp == unchoke_peers.optunchkpeer) break;
					temp = temp->next;
				}
				if(temp != NULL) {
					(unchoke_peers.optunchkpeer)->am_choking = 1;
					create_chock_interested_msg(0,unchoke_peers.optunchkpeer);
				}
			}

			p->am_choking = 0;
			create_chock_interested_msg(1,p);
			unchoke_peers.optunchkpeer = p;
			//printf("*** optunchoke:%s ***\n",p->ip);
			break;
		}

		i++;
	}

	if(rand_num != NULL) { free(rand_num); rand_num = NULL; }
	return 0;
}

// 計算最近一段時間(如10秒)每個peer的上傳下載速度
int compute_rate()
{
	Peer    *p       = peer_head;
	time_t  time_now = time(NULL);
	long    t        = 0;

	while(p != NULL) {
		if(p->last_down_timestamp == 0) {
			p->down_rate  = 0.0f;
			p->down_count = 0;
		} else {
			t = time_now - p->last_down_timestamp;
			if(t == 0)  printf("%s:%d time is 0\n",__FILE__,__LINE__);
			else  p->down_rate = p->down_count / t;
			p->down_count          = 0;
			p->last_down_timestamp = 0;
		}

		if(p->last_up_timestamp == 0) {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区在线观看免费| 国产成人精品三级麻豆| 久久99热99| 久久午夜免费电影| 一区二区三区欧美亚洲| 精品一区二区三区免费| 91久久精品一区二区二区| 欧美精品一区二区精品网| 亚洲精选免费视频| 国产成人午夜99999| 欧美日韩高清一区二区三区| 国产欧美日韩麻豆91| 日韩电影在线看| 91麻豆swag| 欧美韩国日本综合| 美国十次综合导航| 欧美午夜精品久久久久久超碰| 久久精品人人做人人爽人人| 丝袜美腿亚洲色图| 色国产精品一区在线观看| 国产欧美一区二区精品秋霞影院| 午夜精品福利一区二区三区蜜桃| 成人黄色免费短视频| 精品久久五月天| 日韩电影一区二区三区| 欧美手机在线视频| 一区二区三区中文在线观看| 成人动漫中文字幕| 欧美—级在线免费片| 国产一区二区福利| 26uuu久久天堂性欧美| 日韩av网站在线观看| 欧美日韩不卡一区二区| 亚洲国产综合视频在线观看| 日本韩国精品一区二区在线观看| 中文字幕一区二区三区四区不卡| 国产精品资源网| 久久精品夜夜夜夜久久| 国产美女精品一区二区三区| 精品成人一区二区三区| 久久精品国产99国产精品| 中文字幕亚洲精品在线观看| 国产成人精品免费在线| 国产欧美精品国产国产专区 | 日本久久精品电影| 亚洲欧洲日韩av| 91蝌蚪国产九色| 一级女性全黄久久生活片免费| 一本一本久久a久久精品综合麻豆 一本一道波多野结衣一区二区 | 国产精品99久久久久久似苏梦涵| 精品国内二区三区| 国产成人午夜电影网| 中文字幕日韩一区二区| 欧洲一区在线观看| 青青国产91久久久久久| 日韩免费观看2025年上映的电影| 国内精品视频一区二区三区八戒 | 久久成人久久鬼色| 婷婷激情综合网| 欧美一区二区三区视频免费播放| 日本va欧美va精品发布| 国产色综合一区| 91视频www| 日日夜夜精品视频天天综合网| 日韩免费视频一区| 波多野结衣在线一区| 一二三四社区欧美黄| 日韩欧美美女一区二区三区| 国产suv一区二区三区88区| 亚洲日本护士毛茸茸| 91.com视频| 成人高清免费观看| 视频在线观看一区| 国产精品你懂的| 欧美日韩五月天| 国产宾馆实践打屁股91| 亚洲一区二区在线观看视频| 精品国产髙清在线看国产毛片| jlzzjlzz亚洲日本少妇| 丝袜美腿亚洲综合| 国产精品久久网站| 精品国一区二区三区| 91福利视频久久久久| 国产美女主播视频一区| 亚洲午夜精品17c| 国产欧美精品国产国产专区| 欧美丰满美乳xxx高潮www| 本田岬高潮一区二区三区| 麻豆精品一区二区av白丝在线| 亚洲色图在线播放| 国产亚洲福利社区一区| 欧美日韩五月天| 91丨porny丨户外露出| 国产乱国产乱300精品| a4yy欧美一区二区三区| 蜜臀av国产精品久久久久| 亚洲免费毛片网站| 国产女同性恋一区二区| 日韩网站在线看片你懂的| 在线欧美小视频| 成人免费视频网站在线观看| 久久成人久久爱| 日韩一区精品视频| 一区二区三区视频在线看| 国产精品美女久久久久av爽李琼| 精品国产一区二区亚洲人成毛片| 欧美性大战久久久久久久蜜臀| jlzzjlzz亚洲女人18| 国产91在线看| 国产一区二区三区在线观看免费| 人人精品人人爱| 三级在线观看一区二区| 亚洲午夜在线电影| 夜夜亚洲天天久久| 亚洲精品国产无天堂网2021| 亚洲欧美在线视频观看| 中文字幕精品综合| 国产精品午夜春色av| 日本一区二区三区在线观看| 久久久精品国产免大香伊| 久久综合九色综合欧美98 | 在线精品视频免费播放| 97精品国产露脸对白| 99精品国产热久久91蜜凸| 成人av在线影院| 99在线视频精品| 日本精品视频一区二区三区| 91高清在线观看| 欧美日韩在线播放三区四区| 欧美日韩1234| 尤物视频一区二区| 亚洲一区二区三区在线| 亚洲电影欧美电影有声小说| 亚洲国产精品人人做人人爽| 亚洲成人av电影在线| 日韩成人午夜电影| 狠狠狠色丁香婷婷综合激情| 国产米奇在线777精品观看| 成人免费视频网站在线观看| 99国产精品久久久久久久久久| 91啪九色porn原创视频在线观看| 色婷婷综合久色| 欧美日韩激情一区| 日韩精品一区二区三区四区视频| wwww国产精品欧美| 亚洲日韩欧美一区二区在线| 偷拍日韩校园综合在线| 韩国av一区二区三区在线观看| 成人在线综合网| 欧美调教femdomvk| 精品国产一区二区三区久久影院| 欧美经典一区二区| 亚洲一卡二卡三卡四卡| 久久国产精品免费| 91丨porny丨首页| 欧美一区国产二区| 精品福利在线导航| 日本一区二区不卡视频| 一片黄亚洲嫩模| 精久久久久久久久久久| 波多野结衣中文字幕一区| 欧美日韩精品福利| 国产三区在线成人av| 亚洲一区二区五区| 国产一区二区三区免费观看| 日本韩国欧美三级| 26uuu成人网一区二区三区| 亚洲柠檬福利资源导航| 免费不卡在线观看| 99久久国产综合色|国产精品| 91精品欧美久久久久久动漫| 国产欧美一区二区三区在线看蜜臀| 亚洲精品日日夜夜| 国产成人综合在线| 欧美丰满高潮xxxx喷水动漫| 中国av一区二区三区| 精品一区二区影视| 欧美日韩国产中文| 一区在线中文字幕| 国产精品夜夜爽| 欧美成人欧美edvon| 亚洲成va人在线观看| k8久久久一区二区三区| 2020国产成人综合网| 日韩成人伦理电影在线观看| 日本道精品一区二区三区| 久久精品男人的天堂| 日本不卡一二三区黄网| 欧美视频日韩视频在线观看| 国产精品进线69影院| 国产一区二区导航在线播放| 日韩午夜激情电影| 爽好久久久欧美精品| 欧美日韩午夜影院| 亚洲小说欧美激情另类| 色偷偷一区二区三区| 最近日韩中文字幕| 成人h动漫精品一区二| 欧美国产国产综合| 成人综合在线视频|