• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            coreBugZJ

            此 blog 已棄。

            匯編調用 C 語言 printf %f 輸出浮點數 float 的問題:4字節 還是 8字節


             1 
             2 // 畢業論文做Pascal編譯器,把編譯生成的中間代碼翻譯為 nasm 匯編調用 C 語言庫函數時,在輸出 float 部分出現問題。
             3 
             4 
             5 // 先說明一下,我安排棧中數據 8字節對齊,不管數據實際大小,都分配 8字節,按最低字節尋址。
             6 // 當然,調用 C 語言函數時的參數棧,還是按 i386 的來。
             7 
             8 
             9 // C printf 格式化字符串
            10 data.add( head + "c_format_float32 : db \'%f\', 0" );
            11 data.add( head + "c_format_float64 : db \'%lf\', 0" );
            12 data.add( head + "c_format_float64G: db \'%G\', 0" );
            13 
            14 
            15 // 棧頂已經是 8字節的 ieee754 double 數據,然后
            16 text.add( line + "push dword c_format_float64G" );
            17 // 或 text.add( line + "push dword c_format_float64" ); 也正確
            18 text.add( head + "call printf" );
            19 text.add( head + "add esp, 12" );
            20 // 生成可執行文件后,運行輸出正確
            21 
            22 
            23 // 棧頂已經是 4字節的 ieee754 float 數據,且不等于0(次棧頂 4字節全零),然后
            24 text.add( line + "push dword c_format_float32" );
            25 text.add( head + "call printf" );
            26 text.add( head + "add esp, 12" );
            27 // 生成可執行文件后,運行輸出 0.000000
            28 
            29 
            30 // 正確的是
            31 // 棧頂已經是 4字節的 ieee754 float 數據,然后
            32 // 先把4字節的float 轉為 8字節的double
            33 text.add( line + "fld dword [esp]" );
            34 text.add( head + "fstp qword [esp]" ); // 8字節對齊,未覆蓋棧中數據
            35 text.add( head + "push dword c_format_float32" );
            36 text.add( head + "call printf" );
            37 text.add( head + "add esp, 12" );
            38 // 生成可執行文件后,運行輸出正確
            39 
            40 

            結論:
             C 語言的 printf 使用 %f 來輸出 float 時,實際上先把 4字節的float轉化為 8字節的double,然后訪問了棧上的 8字節數據。

            (環境:Ubuntu12.04 32位 intel i3 nasm gcc)

            posted on 2013-04-29 16:51 coreBugZJ 閱讀(3179) 評論(2)  編輯 收藏 引用 所屬分類: AssembleLinuxCPUGPUProgrammingLanguage

            Feedback

            # re: 匯編調用 C 語言 printf %f 輸出浮點數 float 的問題:4字節 還是 8字節 2013-05-09 19:17 ilvu

            印象里可變參數壓棧是4字節對齊的。試一試char作為參數看看。  回復  更多評論   

            # re: 匯編調用 C 語言 printf %f 輸出浮點數 float 的問題:4字節 還是 8字節 2013-05-09 22:34 coreBugZJ

            @ilvu
            i386的參數原則上全都放在棧中,是4字節對齊的,char和short也是4字節對齊。  回復  更多評論   


            久久久久久久综合日本亚洲| 国产V综合V亚洲欧美久久| 久久人妻少妇嫩草AV蜜桃| 一本久久免费视频| 久久国产精品一国产精品金尊| 青青草原综合久久| 久久人人添人人爽添人人片牛牛 | 久久精品国产亚洲av高清漫画| 久久AV高清无码| 国产69精品久久久久APP下载| 久久人爽人人爽人人片AV| 久久国产香蕉视频| 久久精品欧美日韩精品| 香港aa三级久久三级老师2021国产三级精品三级在 | 狠狠人妻久久久久久综合蜜桃| 国内精品伊人久久久久妇| 亚洲综合久久综合激情久久| 无码AV中文字幕久久专区| 久久婷婷人人澡人人| 色综合合久久天天综合绕视看| 国内精品久久国产| 久久夜色撩人精品国产| 国产成人无码精品久久久免费| 久久久久人妻精品一区二区三区| 亚洲国产成人精品久久久国产成人一区二区三区综 | 国产精品热久久无码av| 97精品伊人久久大香线蕉app| 久久无码一区二区三区少妇| 91亚洲国产成人久久精品| 777米奇久久最新地址| 久久久久人妻精品一区| 色婷婷综合久久久久中文一区二区 | 一本久久a久久精品综合夜夜| 亚洲国产欧美国产综合久久| 国产亚洲美女精品久久久2020| 久久人人爽人人澡人人高潮AV | 久久人妻少妇嫩草AV无码专区 | 久久久久综合国产欧美一区二区| 精品一区二区久久久久久久网站| 国产精品久久久久久一区二区三区| 久久婷婷五月综合色高清|