图解散列函数

图解散列函数_第1张图片

图解散列函数_第2张图片

图解散列函数_第3张图片

图解散列函数_第4张图片

散列函数将输入映射到数字。

1.必须是一致的,apple每次都返回4。

2.不同的内容,映射不同的数字,输入什么都返回4就没有意义了。

散列,hash。

book = dict()

book['apple'] = 0.67
book['milk']  = 1.49
book['avocado'] = 1.49
print(book) #{'apple': 0.67, 'milk': 1.49, 'avocado': 1.49}

print(book['apple']) #0.67

检测是否已经投票

图解散列函数_第5张图片

voted = {}
def check_voter(name):
    if voted.get(name):
        print ("kick them out!")
    else:
        voted[name] = True
        print ("let them vote!")

check_voter("tom")  # let them vote!
check_voter("mike") # let them vote!
check_voter("mike") # kick them out!

应用于缓存处理

图解散列函数_第6张图片

cache = {}
def get_page(url):
    if cache.get(url):
        print("缓存获取");
        return cache[url]
    else:
        print("第一次获取");
        data = get_data_from_server(url)
        cache[url] = data
        return data


def get_data_from_server(url):
    return url+"数据";

print(get_page("cnblogs.com")); #第一次获取 cnblogs.com数据
print(get_page("cnblogs.com")); #缓存获取 cnblogs.com数据

你可能感兴趣的:(图解散列函数)