当前位置: 首页>>代码示例>>Python>>正文


Python random.next方法代码示例

本文整理汇总了Python中random.next方法的典型用法代码示例。如果您正苦于以下问题:Python random.next方法的具体用法?Python random.next怎么用?Python random.next使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在random的用法示例。


在下文中一共展示了random.next方法的11个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Python代码示例。

示例1: rnd_data_len

# 需要导入模块: import random [as 别名]
# 或者: from random import next [as 别名]
def rnd_data_len(self, buf_size, last_hash, random):
        other_data_size = buf_size + self.server_info.overhead
        # 一定要在random使用前初始化,以保证服务器与客户端同步,保证包大小验证结果正确
        random.init_from_bin_len(last_hash, buf_size)
        # final_pos 总是分布在pos~(data_size_list0.len-1)之间
        # 除非data_size_list0中的任何值均过小使其全部都无法容纳buf
        if other_data_size >= self.data_size_list0[-1]:
            if other_data_size >= 1440:
                return 0
            if other_data_size > 1300:
                return random.next() % 31
            if other_data_size > 900:
                return random.next() % 127
            if other_data_size > 400:
                return random.next() % 521
            return random.next() % 1021

        pos = bisect.bisect_left(self.data_size_list0, other_data_size)
        # random select a size in the leftover data_size_list0
        final_pos = pos + random.next() % (len(self.data_size_list0) - pos)
        return self.data_size_list0[final_pos] - other_data_size 
开发者ID:PaperDashboard,项目名称:shadowsocks,代码行数:23,代码来源:auth_chain.py

示例2: init_data_size

# 需要导入模块: import random [as 别名]
# 或者: from random import next [as 别名]
def init_data_size(self, key):
        if self.data_size_list0:
            self.data_size_list0 = []
        random = xorshift128plus()
        # key xor with key_change_datetime_key
        new_key = bytearray(key)
        new_key_str = ''
        for i in range(0, 8):
            new_key[i] ^= self.key_change_datetime_key_bytes[i]
            new_key_str += chr(new_key[i])
        for i in range(8, len(new_key)):
            new_key_str += chr(new_key[i])
        random.init_from_bin(to_bytes(new_key_str))
        # 补全数组长为12~24-1
        list_len = random.next() % (8 + 16) + (4 + 8)
        for i in range(0, list_len):
            self.data_size_list0.append(int(random.next() % 2340 % 2040 % 1440))
        self.data_size_list0.sort()
        old_len = len(self.data_size_list0)
        self.check_and_patch_data_size(random)
        # if check_and_patch_data_size are work, re-sort again.
        if old_len != len(self.data_size_list0):
            self.data_size_list0.sort() 
开发者ID:PaperDashboard,项目名称:shadowsocks,代码行数:25,代码来源:auth_chain.py

示例3: rnd_data_len

# 需要导入模块: import random [as 别名]
# 或者: from random import next [as 别名]
def rnd_data_len(self, buf_size, last_hash, random):
        if buf_size >= 1440:
            return 0
        random.init_from_bin_len(last_hash, buf_size)
        pos = bisect.bisect_left(self.data_size_list, buf_size + self.server_info.overhead)
        final_pos = pos + random.next() % (len(self.data_size_list))
        if final_pos < len(self.data_size_list):
            return self.data_size_list[final_pos] - buf_size - self.server_info.overhead

        pos = bisect.bisect_left(self.data_size_list2, buf_size + self.server_info.overhead)
        final_pos = pos + random.next() % (len(self.data_size_list2))
        if final_pos < len(self.data_size_list2):
            return self.data_size_list2[final_pos] - buf_size - self.server_info.overhead
        if final_pos < pos + len(self.data_size_list2) - 1:
            return 0

        if buf_size > 1300:
            return random.next() % 31
        if buf_size > 900:
            return random.next() % 127
        if buf_size > 400:
            return random.next() % 521
        return random.next() % 1021 
开发者ID:NyanChanMeow,项目名称:SSRSpeed,代码行数:25,代码来源:auth_chain.py

示例4: next

# 需要导入模块: import random [as 别名]
# 或者: from random import next [as 别名]
def next(self):
        x = self.v0
        y = self.v1
        self.v0 = y
        x ^= ((x & xorshift128plus.mov_mask) << 23)
        x ^= (y ^ (x >> 17) ^ (y >> 26)) & xorshift128plus.max_int
        self.v1 = x
        return (x + y) & xorshift128plus.max_int 
开发者ID:hao35954514,项目名称:shadowsocksR-b,代码行数:10,代码来源:auth_chain.py

示例5: init_from_bin_len

# 需要导入模块: import random [as 别名]
# 或者: from random import next [as 别名]
def init_from_bin_len(self, bin, length):
        bin += b'\0' * 16
        bin = struct.pack('<H', length) + bin[2:]
        self.v0 = struct.unpack('<Q', bin[:8])[0]
        self.v1 = struct.unpack('<Q', bin[8:16])[0]

        for i in range(4):
            self.next() 
开发者ID:hao35954514,项目名称:shadowsocksR-b,代码行数:10,代码来源:auth_chain.py

示例6: rnd_data_len

# 需要导入模块: import random [as 别名]
# 或者: from random import next [as 别名]
def rnd_data_len(self, buf_size, last_hash, random):
        if buf_size > 1440:
            return 0
        random.init_from_bin_len(last_hash, buf_size)
        if buf_size > 1300:
            return random.next() % 31
        if buf_size > 900:
            return random.next() % 127
        if buf_size > 400:
            return random.next() % 521
        return random.next() % 1021 
开发者ID:hao35954514,项目名称:shadowsocksR-b,代码行数:13,代码来源:auth_chain.py

示例7: udp_rnd_data_len

# 需要导入模块: import random [as 别名]
# 或者: from random import next [as 别名]
def udp_rnd_data_len(self, last_hash, random):
        random.init_from_bin(last_hash)
        return random.next() % 127 
开发者ID:hao35954514,项目名称:shadowsocksR-b,代码行数:5,代码来源:auth_chain.py

示例8: rnd_start_pos

# 需要导入模块: import random [as 别名]
# 或者: from random import next [as 别名]
def rnd_start_pos(self, rand_len, random):
        if rand_len > 0:
            return random.next() % 8589934609 % rand_len
        return 0 
开发者ID:hao35954514,项目名称:shadowsocksR-b,代码行数:6,代码来源:auth_chain.py

示例9: next

# 需要导入模块: import random [as 别名]
# 或者: from random import next [as 别名]
def next(self):
        x = self.v0
        y = self.v1
        self.v0 = y
        x ^= ((x & xorshift128plus.mov_mask) << 23)
        x ^= (y ^ (x >> 17) ^ (y >> 26))
        self.v1 = x
        return (x + y) & xorshift128plus.max_int 
开发者ID:PaperDashboard,项目名称:shadowsocks,代码行数:10,代码来源:auth_chain.py

示例10: init_from_bin_len

# 需要导入模块: import random [as 别名]
# 或者: from random import next [as 别名]
def init_from_bin_len(self, bin, length):
        if len(bin) < 16:
            bin += b'\0' * 16
        self.v0 = struct.unpack('<Q', struct.pack('<H', length) + bin[2:8])[0]
        self.v1 = struct.unpack('<Q', bin[8:16])[0]

        for i in range(4):
            self.next() 
开发者ID:PaperDashboard,项目名称:shadowsocks,代码行数:10,代码来源:auth_chain.py

示例11: check_and_patch_data_size

# 需要导入模块: import random [as 别名]
# 或者: from random import next [as 别名]
def check_and_patch_data_size(self, random):
        # append new item
        # when the biggest item(first time) or the last append item(other time) are not big enough.
        # but set a limit size (64) to avoid stack overflow.
        if self.data_size_list0[-1] < 1300 and len(self.data_size_list0) < 64:
            self.data_size_list0.append((int)(random.next() % 2340 % 2040 % 1440))
            self.check_and_patch_data_size(random) 
开发者ID:PaperDashboard,项目名称:shadowsocks,代码行数:9,代码来源:auth_chain.py


注:本文中的random.next方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。