① 二進制如何編程
1、打開易語言新建一個windows程序進入下圖界面。
② C語言輸出二進制文件的問題
1、打開編譯器,Ctrl+N新建一個文件;
③ java編譯器把java程序編譯成虛擬機可以識別的二進制代碼,稱為什麼
由java編譯器把源文件編譯成虛擬機可以識別的二進制代碼稱為位元組碼。
而位元組碼是由java解釋器去解釋執行的。
④ C語言編程float型數據轉化為2進制數輸出
你先看看這個,如果看不懂,就追問。
《C語言中,float在內存中的儲存方式》:
浮點型變數在計算機內存中佔用4位元組(Byte),即32-bit。
遵循IEEE-754格式標准。 一個浮點數由2部分組成:底數m 和 指數e。
±mantissa × 2exponent (注意,公式中的mantissa 和 exponent使用二進製表示)
底數部分 使用2進制數來表示此浮點數的實際值。
指數部分 佔用8-bit的二進制數,可表示數值范圍為0-255。
但是指數應可 正可負,所以IEEE規定,此處算出的次方須減去127才是真正的指數。所以float的指數可從 -126到128. 底數部分實際是佔用24-bit的一個值,由於其最高位始終為 1 ,所以最高位省去不存儲,在存儲中只有23-bit。
到目前為止, 底數部分 23位 加上指數部分 8位 使用了31位。那麼前面說過,float是佔用4個位元組即32-bit,那麼還有一位是幹嘛用的呢? 還有一位,其實就是4位元組中的最高位,用來指示浮點數的正負,當最高位是1時,為負數,最高位是0時,為正數。
浮點數據就是按下表的格式存儲在4個位元組中:
Address+0 Address+1 Address+2 Address+3 Contents
SEEE EEEE EMMM MMMM MMMM MMMM MMMM MMMM
S: 表示浮點數正負,1為負數,0為正數
E: 指數加上127後的值的二進制數
M: 24-bit的底數(只存儲23-bit)
主意:這里有個特例,浮點數 為0時,指數和底數都為0,但此前的公式不成立。因為2的0次方為1,所以,0是個特例。當然,這個特例也不用認為去干擾,編譯器會自動去識別。 通過上面的格式,我們下面舉例看下-12.5在計算機中存儲的具體數據:
Address+0 Address+1 Address+2 Address+3 Contents
0xC1 0x48 0x00 0x00
接下來我們驗證下上面的數據表示的到底是不是-12.5,從而也看下它的轉換過程。 由於浮點數不是以直接格式存儲,他有幾部分組成,所以要轉換浮點數,首先要把各部分的值分離出來。
Address+0 Address+1 Address+2 Address+3
格式SEEEEEEE EMMMMMMM MMMMMMMM MMMMMMMM
二進制 11000001 01001000 00000000 00000000
16進制 C1 48 00 00
可見:
S: 為1,是個負數。
E:為 10000010 轉為10進制為130,130-127=3,即實際指數部分為3.
M:為 10010000000000000000000。
這里,在底數左邊省略存儲了一個1,
使用 實際底數表示為1.10010000000000000000000 到此,我們吧三個部分的值都拎出來了,現在,我們通過指數部分E的值來調整底數部分M的值。調整方法為:如果指數E為負數,底數的小數點向左移,如果指數E為正數,底數的小數點向右移。小數點移動的位數由指數E的絕對值決定。 這里,E為正3,使用向右移3為即得: 1100.10000000000000000000 至次,這個結果就是12.5的二進制浮點數,將他換算成10進制數就看到12.5了,如何轉換,看下面: 小數點左邊的1100 表示為 (1 × 23) + (1 × 22) + (0 × 21) + (0 × 20), 其結果為 12 。 小數點右邊的 .100… 表示為 (1 × 2-1) + (0 × 2-2) + (0 × 2-3) + ... ,其結果為.5 。 以上二值的和為12.5, 由於S 為1,使用為負數,即-12.5 。所以,16進制 0XC1480000 是浮點數 -12.5 。
上面是如何將計算機存儲中的二進制數如何轉換成實際浮點數,下面看下如何將一浮點數裝換成計算機存儲格式中的二進制數。 舉例將17.625換算成 float型。
首先,將17.625換算成二進制位:
10001.101 ( 0.625 = 0.5+0.125, 0.5 即 1/2, 0.125即 1/8 如果不會將小數部分轉換成二進制,請參考其他書籍。)
再將 10001.101 向右移,直到小數點前只剩一位 成了 1.0001101 x 2的4次方(因為右移了4位)。此時 我們的底數M和指數E就出來了: 底數部分M,因為小數點前必為1,所以IEEE規定只記錄小數點後的就好,所以此處底數為 0001101 。 指數部分E,實際為4,但須加上127,固為131,即二進制數 10000011 符號部分S,由於是正數,所以S為0. 綜上所述,17.625的 float 存儲格式就是: 0 10000011 00011010000000000000000 轉換成16進制:0x41 8D 00 00 所以,一看,還是佔用了4個位元組。
下面,我做了個有趣的實驗,就是由用戶輸入一個浮點數,程序將這個浮點數在計算機中存儲的二進制直接輸出,來看看我們上面所將的那些是否正確。 有興趣同學可以到VC6.0中去試試~!
#include<iostream.h>
#define uchar unsigned char
void binary_print(uchar c)
{
for(int i = 0; i < 8; ++i)
{
if((c << i) & 0x80)
cout << '1'; else cout << '0';
}
cout << ' ';
}
void main()
{
float a;
uchar c_save[4];
uchar i;
void *f;
f = &a;
cout<<"請輸入一個浮點數:";
cin>>a;
cout<<endl;
for(i=0;i<4;i++)
{
c_save[i] = *((uchar*)f+i);
}
cout<<"此浮點數在計算機內存中儲存格式如下:"<<endl;
for(i=4;i!=0;i--)
binary_print(c_save[i-1]);
cout<<endl;
}
⑤ C語言中怎樣輸出一個二進制的數
//我們用按位運算符:右移>>和按位運算符與^,這兩個功能就可以實現。
#include<stdio.h>
voidprintBinary(intnumber);//這是聲明一個自定義的函數,讓編譯器知道我們造了一個這么個函數,功能:將整數以二進制形式輸出。
intmain()
{
printBinary(22);//括弧裡面可以填上你要輸出的整數,比如要輸出22的二進制形式
return0;
}
voidprintBinary()//自定義一個函數printBinary
{
inttemp=sizeof(number)-1;//定義一個變數:如果你的編譯器是32位的,也就是inttemp=31;
while(temp>=0)//temp是循環的次數,不需要糾結判斷是>=還是>,寫完之後檢驗一下就知道哪個對了。
intvalue=number>>temp^1;//a>>temp。temp移動後,是把這個整數的二進制形式中最後一位,依次與1進行按位與運算。假如temp=31,就是把這個整數的二進制形式右移31位,只剩下了這個整數的二進制形式的開頭第一個數字,然後與1進行按位與運算。真則為1,假則為0。
printf("%d",value);//每次輸出整數的二進制形式的一個數字,從開頭開始輸出。.
temp--;//按位右移循環,直到把整數內存中所有的位移完畢。從內存中二進制形式的第一位開始。
}
⑥ C語言中怎樣調用函數將十進制轉換成二進制
1、打開visualC++6.0-文件-新建-文件-C++SourceFile。
⑦ 38編譯器怎麼實現
將輸入的二進制代碼轉換成特定的高(低)電平信號輸出的邏輯電路。
38編譯器是一種全解碼器(二進制解碼器)。全解碼器的輸入是3位二進制代碼,3位二進制代碼共有8種組合,故輸出是與這8種組合一一對應的8個輸出信號。解碼器將每種二進制的代碼組合譯成對應的一根輸出線上的高(低)電平信號。
常見的全解碼器有2-4線解碼器、3-8線解碼器、4-16線解碼器等。如果滿足n<2n,稱為部分解碼器,如二-十進制解碼器(又稱4-10解碼器)、顯示解碼器等。
⑧ 編譯器編譯出的可執行二進制信息在 Windows 操作系統上的規則是什麼
不明白你問的是什麼意思。
你可以了解下匯編語言和二進制。機器最終只認識二進制的數據。二進制數據只有0和1.一個代表開,一個代表關,然後通過這個「開關」來控制計算機
⑨ c語言是如何編譯成二進制
計算機專業有門課程叫做《編譯原理》,詳細講述了怎麼把高級語言翻譯成匯編語言活著機器能看懂的二進制代碼。
簡單的說,C語言是通過編譯器翻譯成二進制代碼的(就像英譯漢的軟體把英文翻譯成漢語一樣。把高級語言翻譯成機器語言過程很復雜,學了編譯原理就懂了)。還有編譯器可以用各種語言編寫,C語言可以被用C語言寫的編譯器來編譯。
⑩ 做&運算時編譯器會自動將數轉為二進制
不是「做&運算時編譯器會自動將數轉為二進制」,而是存儲在內存中的,本來就已經是二進制的數據了。