欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

解決python3 整數(shù)數(shù)組轉(zhuǎn)bytes的效率問題

 更新時(shí)間:2021年03月08日 11:55:39   作者:b0ring  
這篇文章主要介紹了解決python3 整數(shù)數(shù)組轉(zhuǎn)bytes的效率問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧

昨天在做一道CTF題的時(shí)候碰到了一個(gè)圖片異或的問題,操作大概如下:

將一個(gè)圖片讀入,然后每字節(jié)進(jìn)行異或操作,核心代碼可簡化為以下:

#coding:utf-8
'''
 @DateTime: 2017-11-25 13:51:33
 @Version: 1.0
 @Author: Unname_Bao
'''
import six
key = b'\xdcd~\xb6^g\x11\xe1U7R\x18!+9d\xdcd~\xb6^g\x11\xe1U7R\x18!+9d'
with open('flag.encrypted','rb') as f:
 c = f.read()
flag = b''
for i in range(32):
 flag += six.int2byte(key[i%32]^c[i])
with open('flag.png','wb') as f:
 f.write(flag)

然后就碰到了一個(gè)效率問題,跑了十幾分鐘都沒有跑出結(jié)果,起初以為是類型轉(zhuǎn)換的問題,因?yàn)楸容^急,于是換了成了C++的代碼去解決,后來一直沒多想。

今天閑下來的時(shí)候才發(fā)現(xiàn)代碼之前的代碼中存在一個(gè)非常大的問題:

內(nèi)存申請問題

由于flag.encrypted文件大小為6.47MB之大,由于我的腳本思路是不斷在byte數(shù)組后添加,但忽略了其本質(zhì)。

就是在內(nèi)存申請過程中,由于數(shù)組長度最終為600+W大小,期間存在多次數(shù)組內(nèi)存不夠,需要重新申請內(nèi)存的問題,而python中的內(nèi)存申請顯然沒有C++的vector的push_back有效率。

而且python中,無論是list、string還是byte,也沒有reserve這種函數(shù),不能預(yù)留內(nèi)存空間(這時(shí)候真的要吐槽一下python設(shè)計(jì)者對速度優(yōu)化的考量了)。

于是只能用另一種方法進(jìn)行優(yōu)化,就是先用list申請一個(gè)需求大小的內(nèi)存空間,然后再轉(zhuǎn)為bytes使用,

代碼如下:

#coding:utf-8
'''
 @DateTime: 2017-11-26 14:09:29
 @Version: 2.0
 @Author: Unname_Bao
'''
key = b'\xdcd~\xb6^g\x11\xe1U7R\x18!+9d\xdcd~\xb6^g\x11\xe1U7R\x18!+9d'
with open('flag.encrypted','rb') as f:
 c = f.read()
flag = list('1'*len(c))
for i in range(len(c)):
 flag[i] = key[i%32]^c[i]
flag = bytes(flag)
with open('flag.png','wb') as f:
 f.write(flag)

這樣寫的話幾乎是瞬間完成任務(wù)了,但還是比C++慢很多,這是不可避免的。

補(bǔ)充:python2與python3的bytes問題

>>> s = '編程'
>>> print s
編程
>>> s
'\xe7\xbc\x96\xe7\xa8\x8b'
>>>

在python2中直接調(diào)用字符串的變量的話,會打印其bytes(可以理解成用16進(jìn)制表示字符串的內(nèi)存地址,本質(zhì)還是二進(jìn)制)。在python2中,bytes和str是一回事。

為什么要有個(gè)bytes呢?因?yàn)樗袛?shù)據(jù)本質(zhì)都是用二進(jìn)制進(jìn)行儲存的,當(dāng)傳輸數(shù)據(jù)的時(shí)候,要把這些數(shù)據(jù)先轉(zhuǎn)換成二進(jìn)制( bytes)在進(jìn)行傳輸。除此之外,python2里還有個(gè)單獨(dú)的數(shù)據(jù)類型,把字符串解碼后,就會變成unicode。

>>> s
'\xe8\xb7\xaf\xe9\xa3\x9e' #utf-8
>>> s.decode('utf-8')
u'\u8def\u98de' #unicode 在unicode編碼表里對應(yīng)的位置
>>> print(s.decode('utf-8'))
路飛 #unicode 格式的字符

原因是python2的默認(rèn)編碼是ASCII,后來為了支持多國語言,就想弄個(gè)unicode。但是直接把ASCII轉(zhuǎn)成unicode是很費(fèi)勁的,所以龜叔直接搞了一個(gè)新的字符類型,就叫unicode,說白了就是你得在內(nèi)存里先把字符串存成unicode類型

2008年python3出世,來了個(gè)大變革:

1、把字符串的編碼變成了unicode,文件默認(rèn)編碼變成了utf-8。

2、把str 和bytes 做了明確區(qū)分, str 就是unicode格式的字符, bytes就是單純二進(jìn)制還有一個(gè)很重要的是,在python3中,只有unicode給你展示字形,其他的編碼一律用bytes展示,也就是說要你強(qiáng)制使用unicode。

最后再提示一下,Python只要出現(xiàn)各種編碼問題,無非是哪里的編碼設(shè)置出錯(cuò)了

常見編碼錯(cuò)誤的原因有:

Python解釋器的默認(rèn)編碼

Python源文件文件編碼

Terminal使用的編碼

操作系統(tǒng)的語言設(shè)置

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

相關(guān)文章

  • Python中sorted()函數(shù)的強(qiáng)大排序技術(shù)實(shí)例探索

    Python中sorted()函數(shù)的強(qiáng)大排序技術(shù)實(shí)例探索

    排序在編程中是一個(gè)基本且重要的操作,而Python的sorted()函數(shù)則為我們提供了強(qiáng)大的排序能力,在本篇文章中,我們將深入研究不同排序算法、sorted()?函數(shù)的靈活性,以及各種排序場景下的最佳實(shí)踐
    2024-01-01
  • Java多線程編程中ThreadLocal類的用法及深入

    Java多線程編程中ThreadLocal類的用法及深入

    這篇文章主要介紹了Java多線程編程中ThreadLocal類的用法及深入,嘗試了自己實(shí)現(xiàn)一個(gè)ThreadLocal類以及對相關(guān)的線程安全問題進(jìn)行討論,需要的朋友可以參考下
    2016-06-06
  • 深入理解Python虛擬機(jī)中字節(jié)(bytes)的實(shí)現(xiàn)原理及源碼剖析

    深入理解Python虛擬機(jī)中字節(jié)(bytes)的實(shí)現(xiàn)原理及源碼剖析

    在本篇文章當(dāng)中主要給大家介紹在?cpython?內(nèi)部,bytes?的實(shí)現(xiàn)原理、內(nèi)存布局以及與?bytes?相關(guān)的一個(gè)比較重要的優(yōu)化點(diǎn)——?bytes?的拼接,需要的可以參考一下
    2023-03-03
  • Windows下安裝python2.7及科學(xué)計(jì)算套裝

    Windows下安裝python2.7及科學(xué)計(jì)算套裝

    這篇文章主要向大家介紹的是在windows系統(tǒng)下安裝python 2.7以及numpy安裝、six安裝、dateutil安裝、pyparsing安裝、matplotlib安裝和scipy安裝的方法,分享給大家,需要的小伙伴可以參考下,相對來說,windows下的安裝還是比較簡單的。
    2015-03-03
  • 深入了解Python的類與模塊化

    深入了解Python的類與模塊化

    這篇文章主要介紹了Python中的面向?qū)ο缶幊谭妒揭约澳K化思想,并給出相應(yīng)的實(shí)戰(zhàn)示例及解釋,對我們的學(xué)習(xí)和工作都有一定的價(jià)值,感興趣的小伙伴可以了解一下
    2021-12-12
  • 使用Python編寫Linux系統(tǒng)守護(hù)進(jìn)程實(shí)例

    使用Python編寫Linux系統(tǒng)守護(hù)進(jìn)程實(shí)例

    這篇文章主要介紹了使用Python編寫Linux系統(tǒng)守護(hù)進(jìn)程實(shí)例,本文先是講解了什么是守護(hù)進(jìn)程,然后給出了一個(gè)Python語言的簡單實(shí)現(xiàn),需要的朋友可以參考下
    2015-02-02
  • 如何使用pandas對超大csv文件進(jìn)行快速拆分詳解

    如何使用pandas對超大csv文件進(jìn)行快速拆分詳解

    Pandas是Python語言的一個(gè)擴(kuò)展程序庫,提供高性能、易于使用的數(shù)據(jù)結(jié)構(gòu)和數(shù)據(jù)分析工具,下面這篇文章主要給大家介紹了關(guān)于如何使用pandas對超大csv文件進(jìn)行快速拆分的相關(guān)資料,需要的朋友可以參考下
    2022-07-07
  • python Pandas時(shí)序數(shù)據(jù)處理

    python Pandas時(shí)序數(shù)據(jù)處理

    這篇文章主要介紹了python Pandas時(shí)序數(shù)據(jù)處理,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-06-06
  • python讀取查看npz/npy文件數(shù)據(jù)以及數(shù)據(jù)完全顯示方法實(shí)例

    python讀取查看npz/npy文件數(shù)據(jù)以及數(shù)據(jù)完全顯示方法實(shí)例

    前兩天從在GitHub下載了一個(gè)代碼,其中的數(shù)據(jù)集是.npz結(jié)尾的文件,之前沒有見過不知道如何處理,下面這篇文章主要給大家介紹了關(guān)于python讀取查看npz/npy文件數(shù)據(jù)以及數(shù)據(jù)完全顯示方法的相關(guān)資料,需要的朋友可以參考下
    2022-04-04
  • pip命令突然無法使用問題以及解決

    pip命令突然無法使用問題以及解決

    當(dāng)你在使用pip安裝Python庫時(shí)遇到問題,可以嘗試以下兩種解決方案,第一種是直接在Scripts文件夾內(nèi)使用CMD命令進(jìn)行安裝,第二種是將Scripts的路徑設(shè)置為系統(tǒng)環(huán)境變量,這樣就可以直接在dos中使用pip install進(jìn)行安裝了,以上解決方案僅供參考,如有更好的方法歡迎交流分享
    2024-10-10

最新評論