[英]An interesting result when I typecast te output
輸入輸出時,我觀察到一個有趣的結果:
這是代碼片段:
int bitSize = (int)log10(1.0*16)/log10(2.0); //bistsize = 3 it should be 4
int temp = log10(1.0*16)/log10(2.0); //temp = 4
基本上我想采用應該為4的log2(16)。我認為我對類型轉換的理解是錯誤的。 有什么建議么?
謝謝
我認為您只是在轉換第一個log(..)
函數的輸出。 在整個表達式周圍加上括號:
int bitSize = (int)(log10(1.0*16)/log10(2.0));
嘗試:
int bitSize = static_cast<int>(log10(1.0*16)/log10(2.0));
新的C ++強制轉換的好處之一是,它們用括號括起了參數,因此很清楚您要強制轉換的內容。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.