本文整理匯總了Python中mmap.PAGESIZE屬性的典型用法代碼示例。如果您正苦於以下問題:Python mmap.PAGESIZE屬性的具體用法?Python mmap.PAGESIZE怎麽用?Python mmap.PAGESIZE使用的例子?那麽, 這裏精選的屬性代碼示例或許可以為您提供幫助。您也可以進一步了解該屬性所在類mmap
的用法示例。
在下文中一共展示了mmap.PAGESIZE屬性的11個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: __init__
# 需要導入模塊: import mmap [as 別名]
# 或者: from mmap import PAGESIZE [as 別名]
def __init__(self, *args, **kwds):
## Create shared memory for rendered image
#pg.dbg(namespace={'r': self})
if sys.platform.startswith('win'):
self.shmtag = "pyqtgraph_shmem_" + ''.join([chr((random.getrandbits(20)%25) + 97) for i in range(20)])
self.shm = mmap.mmap(-1, mmap.PAGESIZE, self.shmtag) # use anonymous mmap on windows
else:
self.shmFile = tempfile.NamedTemporaryFile(prefix='pyqtgraph_shmem_')
self.shmFile.write(b'\x00' * (mmap.PAGESIZE+1))
fd = self.shmFile.fileno()
self.shm = mmap.mmap(fd, mmap.PAGESIZE, mmap.MAP_SHARED, mmap.PROT_WRITE)
atexit.register(self.close)
GraphicsView.__init__(self, *args, **kwds)
self.scene().changed.connect(self.update)
self.img = None
self.renderTimer = QtCore.QTimer()
self.renderTimer.timeout.connect(self.renderView)
self.renderTimer.start(16)
示例2: _malloc
# 需要導入模塊: import mmap [as 別名]
# 或者: from mmap import PAGESIZE [as 別名]
def _malloc(self, size):
# returns a large enough block -- it might be much larger
i = bisect.bisect_left(self._lengths, size)
if i == len(self._lengths):
length = self._roundup(max(self._size, size), mmap.PAGESIZE)
self._size *= 2
info('allocating a new mmap of length %d', length)
arena = Arena(length)
self._arenas.append(arena)
return (arena, 0, length)
else:
length = self._lengths[i]
seq = self._len_to_seq[length]
block = seq.pop()
if not seq:
del self._len_to_seq[length], self._lengths[i]
(arena, start, stop) = block
del self._start_to_block[(arena, start)]
del self._stop_to_block[(arena, stop)]
return block
示例3: _malloc
# 需要導入模塊: import mmap [as 別名]
# 或者: from mmap import PAGESIZE [as 別名]
def _malloc(self, size):
# returns a large enough block -- it might be much larger
i = bisect.bisect_left(self._lengths, size)
if i == len(self._lengths):
length = self._roundup(max(self._size, size), mmap.PAGESIZE)
self._size *= 2
util.info('allocating a new mmap of length %d', length)
arena = Arena(length)
self._arenas.append(arena)
return (arena, 0, length)
else:
length = self._lengths[i]
seq = self._len_to_seq[length]
block = seq.pop()
if not seq:
del self._len_to_seq[length], self._lengths[i]
(arena, start, stop) = block
del self._start_to_block[(arena, start)]
del self._stop_to_block[(arena, stop)]
return block
示例4: __init__
# 需要導入模塊: import mmap [as 別名]
# 或者: from mmap import PAGESIZE [as 別名]
def __init__(self, address, port, timeout, buffer_size=PAGESIZE,
lock_class=Semaphore):
self.address = address
self.port = port
self.timeout = timeout
self.buffer = b''
self.buffer_size = buffer_size
self.socket = None
self.lock = lock_class()
示例5: __init__
# 需要導入模塊: import mmap [as 別名]
# 或者: from mmap import PAGESIZE [as 別名]
def __init__(self, size=mmap.PAGESIZE):
self._lastpid = os.getpid()
self._lock = threading.Lock()
self._size = size
self._lengths = []
self._len_to_seq = {}
self._start_to_block = {}
self._stop_to_block = {}
self._allocated_blocks = set()
self._arenas = []
# list of pending blocks to free - see free() comment below
self._pending_free_blocks = []
示例6: test_mmap_find_large
# 需要導入模塊: import mmap [as 別名]
# 或者: from mmap import PAGESIZE [as 別名]
def test_mmap_find_large():
P10 = PAGESIZE * 10
P11 = PAGESIZE * 11
f = open(TESTFN, 'w+')
try:
f.write((P10 - 1) * '\0')
f.write('foofoo')
f.write('\0' * PAGESIZE)
f.write('foo')
f.flush()
m = mmap.mmap(f.fileno(), P11 + 8)
f.close()
AreEqual(m.find('foo'), P10 - 1)
AreEqual(m.find('foo', P10 - 1), P10 - 1)
AreEqual(m.find('foo', P10), P10 + 2)
AreEqual(m.find('foo', P10 + 173), P11 + 5)
AreEqual(m.find('foo', P10 + 173, P11 + 7), -1)
finally:
m.close()
try:
f.close()
except OSError:
pass
mmap_tearDown()
示例7: test_mmap_rfind_large
# 需要導入模塊: import mmap [as 別名]
# 或者: from mmap import PAGESIZE [as 別名]
def test_mmap_rfind_large():
P10 = PAGESIZE * 10
P11 = PAGESIZE * 11
f = open(TESTFN, 'w+')
try:
f.write((P10 - 1) * '\0')
f.write('foofoo')
f.write('\0' * PAGESIZE)
f.write('foo')
f.flush()
m = mmap.mmap(f.fileno(), P11 + 8)
f.close()
AreEqual(m.rfind('foo'), P11 + 5)
AreEqual(m.rfind('foo', 651, P11 - 117), P10 + 2)
AreEqual(m.rfind('foo', 475, P10 + 5), P10 + 2)
AreEqual(m.rfind('foo', 475, P10 + 4), P10 - 1)
AreEqual(m.rfind('foo', P10 + 4, P11 + 7), -1)
AreEqual(m.rfind('foo', P10 + 4), P11 + 5)
finally:
m.close()
try:
f.close()
except OSError:
pass
mmap_tearDown()
#--MAIN------------------------------------------------------------------------
示例8: _decompress_dwarf_section
# 需要導入模塊: import mmap [as 別名]
# 或者: from mmap import PAGESIZE [as 別名]
def _decompress_dwarf_section(section):
""" Returns the uncompressed contents of the provided DWARF section.
"""
# TODO: support other compression formats from readelf.c
assert section.size > 12, 'Unsupported compression format.'
section.stream.seek(0)
# According to readelf.c the content should contain "ZLIB"
# followed by the uncompressed section size - 8 bytes in
# big-endian order
compression_type = section.stream.read(4)
assert compression_type == b'ZLIB', \
'Invalid compression type: %r' % (compression_type)
uncompressed_size = struct.unpack('>Q', section.stream.read(8))[0]
decompressor = zlib.decompressobj()
uncompressed_stream = BytesIO()
while True:
chunk = section.stream.read(PAGESIZE)
if not chunk:
break
uncompressed_stream.write(decompressor.decompress(chunk))
uncompressed_stream.write(decompressor.flush())
uncompressed_stream.seek(0, io.SEEK_END)
size = uncompressed_stream.tell()
assert uncompressed_size == size, \
'Wrong uncompressed size: expected %r, but got %r' % (
uncompressed_size, size,
)
return section._replace(stream=uncompressed_stream, size=size)
示例9: read_all_values_from_file
# 需要導入模塊: import mmap [as 別名]
# 或者: from mmap import PAGESIZE [as 別名]
def read_all_values_from_file(filename):
with open(filename, 'rb') as infp:
# Read the first block of data, including the first 4 bytes which tell us
# how much of the file (which is preallocated to _INITIAL_MMAP_SIZE bytes) is occupied.
data = infp.read(mmap.PAGESIZE)
used = _unpack_integer(data, 0)[0]
if used > len(data): # Then read in the rest, if needed.
data += infp.read(used - len(data))
return _read_all_values(data, used)
示例10: test_anon
# 需要導入模塊: import mmap [as 別名]
# 或者: from mmap import PAGESIZE [as 別名]
def test_anon():
print " anonymous mmap.mmap(-1, PAGESIZE)..."
m = mmap.mmap(-1, PAGESIZE)
for x in xrange(PAGESIZE):
verify(m[x] == '\0', "anonymously mmap'ed contents should be zero")
for x in xrange(PAGESIZE):
m[x] = ch = chr(x & 255)
vereq(m[x], ch)
示例11: align_to_mmap
# 需要導入模塊: import mmap [as 別名]
# 或者: from mmap import PAGESIZE [as 別名]
def align_to_mmap(num, round_up):
"""
Align the given integer number to the closest page offset, which usually is 4096 bytes.
:param round_up: if True, the next higher multiple of page size is used, otherwise
the lower page_size will be used (i.e. if True, 1 becomes 4096, otherwise it becomes 0)
:return: num rounded to closest page"""
res = (num // ALLOCATIONGRANULARITY) * ALLOCATIONGRANULARITY
if round_up and (res != num):
res += ALLOCATIONGRANULARITY
# END handle size
return res