好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 解決python3 整數數組轉bytes的效率問題

解決python3 整數數組轉bytes的效率問題

熱門標簽:400電話 申請 條件 crm電銷機器人 云南地圖標注 鄭州智能外呼系統中心 北京外呼電銷機器人招商 南京crm外呼系統排名 電銷機器人 金倫通信 汕頭電商外呼系統供應商 賓館能在百度地圖標注嗎

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

將一個圖片讀入,然后每字節進行異或操作,核心代碼可簡化為以下:

#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)

然后就碰到了一個效率問題,跑了十幾分鐘都沒有跑出結果,起初以為是類型轉換的問題,因為比較急,于是換了成了C++的代碼去解決,后來一直沒多想。

今天閑下來的時候才發現代碼之前的代碼中存在一個非常大的問題:

內存申請問題

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

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

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

于是只能用另一種方法進行優化,就是先用list申請一個需求大小的內存空間,然后再轉為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)

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

補充:python2與python3的bytes問題

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

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

為什么要有個bytes呢?因為所有數據本質都是用二進制進行儲存的,當傳輸數據的時候,要把這些數據先轉換成二進制( bytes)在進行傳輸。除此之外,python2里還有個單獨的數據類型,把字符串解碼后,就會變成unicode。

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

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

2008年python3出世,來了個大變革:

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

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

最后再提示一下,Python只要出現各種編碼問題,無非是哪里的編碼設置出錯了

常見編碼錯誤的原因有:

Python解釋器的默認編碼

Python源文件文件編碼

Terminal使用的編碼

操作系統的語言設置

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • python中int與str互轉方法
  • Python bytes string相互轉換過程解析
  • Python實現byte轉integer

標簽:西寧 梅州 石家莊 浙江 錫林郭勒盟 文山 昆明 懷化

巨人網絡通訊聲明:本文標題《解決python3 整數數組轉bytes的效率問題》,本文關鍵詞  解決,python3,整數,數組,轉,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《解決python3 整數數組轉bytes的效率問題》相關的同類信息!
  • 本頁收集關于解決python3 整數數組轉bytes的效率問題的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 大学生粉嫩无套流白浆嗯啊| 春日野结衣AV一区二区| 亚洲a级大片| 动漫卡通精品3d一区二区| 中国女人精69xxxxxx视频| 女性床激烈叫床声视频免费 | 成年女人黄小视频| 女同裸身洗澡互摸| 香蕉钻洞视频| 久久网免费视频| 十天之后爱上你泰剧观看完整版第五集| 韩国三级《偷妻》| 超级黄色电影| 同志china18体育生| 拳头交19分钟| 男的让女的摸摸自己的腹肌啥意思 | 中日韩AV片免费观看视频| 亚洲AⅤ欧美AⅤ综合AV鲁丝片 | 黄色你懂得| 日本a级作爱片金瓶双艳| 骚虎视频| 毛片****毛片毛片| 泷泽萝拉办公室被弄38分钟AV | 极品岳坶交换| 好大好硬好深好爽的视频| 中国男帅chinese男男Gay相关网站| 和老师一天弄了好几次小说| 91色老久久精品偷偷蜜臀| 久久8精品亚洲X99AV无码| 欧美精品久久久久久久久25P| 姑娘免费观看韩国电影中文版视频| 欧美aa大片| 欧美日韩另类在线| 久久精品国产亚洲7777 剧情介绍| 欧美午夜??AV天堂| 国产在线拍揄拍自揄拍无码资源网| 男男做受呻吟声不断| 精精国产xxxx视频在线播放器| 和田县| 中文字幕在线网址| 欧美色少妇高潮4444|