日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python format 槽中槽_printf中的槽和实参--对比python struct包

發布時間:2025/3/20 python 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python format 槽中槽_printf中的槽和实参--对比python struct包 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

在一個很簡單的printf調用中:

printf( "blit (T:%d, L:%d, W:%d, H:%d) to (T:%d, L:%d, W:%d, H:%d) costs %d

ticks(%dms)\n",

nPositionY, nPositionX, nWidth, nHeight,

nPositionY, nPositionX, nWidth, nHeight,

clkCost, time_ms( clkCost ) );

原意是讓clkCost匹配costs %dticks,讓time_ms(clkCost)匹配(%dms)。

但clkCost是long long類型(8字節),匹配完costs %dticks(4字節)后會侵占后面(%dms)中的位置,直接導致time(clkCost)的值沒有位置輸出。

C中的printf函數沒有參數長度檢查,所以在編譯期間無法發現這個漏洞。

類似的錯誤還有參數長度不足或嚴重不匹配(多見于字符串),直接導致程序crash。

這兩錯誤的本因是printf調用的壓棧、解讀策略:

首先定義兩個名詞:

實參 -- printf中第一個參數之后的參數,即除格式字符串之外的所有參數。

槽?? -- 格式字符串中的匹配點,即%d, %s, %f等。

1. 調用printf壓棧時實參逐個進棧,并不記錄棧中每個實參的具體位置。

2. 解讀格式字符串時每遇到一個槽即從棧中讀取相應字節數進行替換:例如遇到%d則讀4個字節進行替換(讀指針隨即下移);遇到%s則讀取4個字節作為字符串首址讀取字符串并替換(首址錯誤可以導致crash或堆棧溢出);遇到%llx字讀取8個字節進行替換......

這種不檢查長度的替換策略導致的問題中最臭名昭著的莫過于“堆棧溢出攻擊”。本文不詳談。

下面再看看開頭的例子,其中clkCost是8字節類型,進棧后一切變量類型都失去了意義,所有數據只有被解讀時才被賦予意義。cost %dticks中的槽從棧中讀取4字節替換%d,clkCost的高字節則被(%dms)中的槽讀去,格式字符串解讀結束。

不知python的發明人是否多次被此類問題叨擾,在python的"壓棧、解讀"包struct中有明確的長度檢查,即使實參是字符也會要求明確其長度:

cont = 'abcd'

struct.pack( '%ds' % len(cont), cont )

struct.unpack( 's'*len(cont), cont )

不過python中的問題也只有在運行時才會出現,這一點并不比C優越,但python拋出的異常可以提供更多的錯誤信息,比C的直接crash要來的溫和很多。

閱讀(1337) | 評論(0) | 轉發(0) |

總結

以上是生活随笔為你收集整理的python format 槽中槽_printf中的槽和实参--对比python struct包的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 依依成人av | 欧美乱大交xxxxx | 搞黄网站在线观看 | 亚洲久久久久久 | av网址免费观看 | 操综合 | 亚洲一区免费在线 | 精品国模 | 蜜臀aⅴ免费一区二区 | 香蕉手机网 | 精品二区在线 | 看全黄大色黄大片美女人 | 色亚洲成人 | 手机看片福利在线 | 一级性视频 | 成人毛片在线精品国产 | 国产日韩一区二区在线 | 欧美骚少妇 | 欧美双性人妖o0 | 精品人妻一区二区三区四区在线 | 日韩一区不卡视频 | 成人国产精品 | 97av免费视频| 国产一区成人 | 国产性猛交xx乱 | 视频一区二区在线观看 | 亚洲综合在线播放 | 国产女人18水真多18精品一级做 | 成年人三级网站 | 青青伊人久久 | 成人在线免费视频 | 永久精品 | 国产97色 | 综合激情av | 日韩午夜视频在线 | 少妇裸体淫交视频免费看高清 | 欧美激情图区 | 亚洲天堂网一区 | 少妇性生活视频 | 天堂在线91 | 日本三级视频在线观看 | 欧美一区二区性久久久 | 久久久久黄色 | 国产精品丝袜视频无码一区69 | h片在线看| www.黄色av| 日韩高清中文字幕 | 亚洲av无码乱码国产精品久久 | 在线观看视频二区 | 99在线免费 | 日韩专区一区二区三区 | 国产成人在线观看网站 | 德国性经典xxxx性hd | 欧美精品在线第一页 | 3344成人| 成年网站在线播放 | 久久久久久久美女 | 在线视频观看一区二区 | 欧美日韩另类一区 | 影音先锋亚洲资源 | 久久久午夜精品 | 午夜影院在线看 | jizz日本在线 | 91久久精品国产91性色tv | 丁香花高清在线观看完整动漫 | 欧美一级专区免费大片 | 日韩一级片在线 | 国产老女人乱淫免费可以 | 国产乱子轮xxx农村 岛国久久久 | 五月婷婷色 | 超碰人操 | 国产高清无遮挡 | 一区二区三区高清在线 | 翔田千里88av中文字幕 | 日批免费网站 | 黄色一级大片在线免费看国产一 | 一区二区三区精品免费视频 | 免费观看已满十八岁 | 亚洲成人播放器 | 麻豆免费网站 | 在线观看黄色片 | 欧美一级专区免费大片 | 91视频直接看 | 国产cao| 一起草av在线 | 国语对白做受xxxxx在线中国 | 亚洲人免费 | 欧美中文字幕 | 免费毛片大全 | 少妇网站在线观看 | 免费网站av | 中文字幕av在线免费观看 | 麻豆成人久久精品一区二区三区 | 日韩欧美在线观看视频 | 欧美视频在线一区 | 久久在线一区二区 | 激情超碰 | 成年人高清视频 | 三区在线 |