hash()用于获取取一个对象(字符串或者数值等)的哈希值。
hash(object)
object -- 对象;
返回对象的哈希值。
hash() 函数可以应用于数字、字符串和对象,不能直接应用于 list、set、dictionary。
print(type(hash(12345))) # <class 'int'> print(hash(12345)) # 12345 print(type(hash('python'))) # <class 'int'> print(hash('python')) # 3210518347997653027 print(hash(str([1,2,3]))) # 368648644522079440 print(hash('Python中文网')) # 1671729848160238081 print(hash(['www','python-china','com'])) # 报错:TypeError: unhashable type: 'list' class test(object): a = 'python-china' t = test() print(hash(t)) # 9223363266462020569
在 hash() 对对象使用时,所得的结果不仅和对象的内容有关,还和对象的 id(),也就是内存地址有关。
class Test: def __init__(self, i): self.i = i for i in range(10): t = Test(1) print(hash(t), id(t)) # 输出的结果是不同的
通过一定的哈希算法(典型的有MD5,SHA-1等),将一段较长的数据映射为较短小的数据,这段小数据就是大数据的哈希值。他有这样一个特点,他是唯一的,一旦大数据发生了变化,哪怕是一个微小的变化,他的哈希值也会发生变化。
另外一方面,既然是DNA,那就保证了没有两个数据的哈希值是完全相同的。
哈希值,即HASH值,是通过对文件内容进行加密运算得到的一组二进制值,主要用途是用于文件校验或签名。正是因为这样的特点,它常常用来判断两个文件是否相同。
比如,从网络上下载某个文件,只要把这个文件原来的哈希值同下载后得到的文件的哈希值进行对比,如果相同,则表示两个文件完全一致,下载过程没有损坏文件。而如果不一致,则表明下载得到的文件跟原来的文件不同,文件在下载过程中受到了损坏。
hash() 函数的对象字符不管有多长,返回的 hash 值都是固定长度的,也用于校验程序在传输过程中是否被第三方(木马)修改,如果程序(字符)在传输过程中被修改hash值即发生变化,如果没有被修改,则 hash 值和原始的 hash 值吻合,只要验证 hash 值是否匹配即可验证程序是否带木马(病毒)。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
长按识别二维码并关注微信
更方便到期提醒、手机管理