c語言十六進制轉字元串
1. c語言程序,怎麼把16進制轉成字元:
我想你的問題只是將數字轉換為字元對吧,那麼我就不幫你做全文多行的源碼了,我做了一行轉換的,你可以再在外層嵌套一個循環,並使用二維數組來實現全文多行的ASCII碼轉換:
#include "Stdio.h"
#include "Conio.h"
int main(void)
{
int num[10],i=0;
while(getchar() != '\n')
{
getchar();
scanf("%x",&num[i]);
printf("%c",num[i]);
i++;
}
getch();
return 0;
}
原理是這樣的:
你每次的四個位元組的格式都是\xyy的形式,我只要讀入那個十六進制數就可以了,用scanf("%x",&num[i]);語句就可以讀入十六進制數字,將一行的十六進制數在循環中全部取出存放在一維數組中。
在輸出方面我投了個懶,直接讀入就輸出了,不過這個不是關鍵了,關鍵是以printf("%c",num[i]);語句輸出,編譯器就會自行把十六進制數轉換為ascii碼所對應的字元並輸出。
現在你明白了么,就是以格式化的輸入輸出實現讀入的是十六進制數,輸出的是字元。(那兩個getchar()是分別讀入字元\和x的哈~~)
2. C語言:怎麼將十六進制字元串轉換成二進制字元串,誰幫我寫個函數
十六進制轉成十進制的函數:
//返回16進制字元串s對應的整數值,遇到任何一個非法字元都返回-1。
int
HexToDec(char
*s)
{
char
*p
=
s;
//空串返回0。
if(*p
==
'\0')
return
0;
//忽略開頭的'0'字元
while(*p
==
'0')
p++;
int
dec
=
0;
char
c;
//循環直到字元串結束。
while(c
=
*p++)
{
//dec乘16
dec
<<=
4;
//數字字元。
if(c
>=
'0'
&&
c
<=
'9')
{
dec
+=
c
-
'0';
continue;
}
//小寫abcdef。
if(c
>=
'a'
&&
c
<=
'f')
{
dec
+=
c
-
'a'
+
10;
continue;
}
//大寫ABCDEF。
if(c
>=
'A'
&&
c
<=
'F')
{
dec
+=
c
-
'A'
+
10;
continue;
}
//沒有從任何一個if語句中結束,說明遇到了非法字元。
return
-1;
}
//正常結束循環,返回10進制整數值。
return
dec;
}
十進制轉成二進制的函數:
/*遞歸法求二進制數*/
#include
void
printb(int
x,int
n);
void
main()
{
int
x;
printf("input
number:");
scanf("%d",&x);
printf("number
of
decimal
form:
%d\n",x);
printb(x,sizeof(int)*8);
putchar('\n');
}
void
printb(int
x,int
n)
{
if(n>0)
{
putchar('0'+(
(unsigned)(x
&
(1<<(n-1)
)
)>>(n-1)));
printb(x,n-1);
}
}
3. C語言中十六進制字元數組轉化為字元串
#include <stdio.h>
unsigned char s_des[100] = {0};
int length = 9;
unsigned char s_src[length] = {0xFE,0x01,0x52,0xFF,0xEF,0xBA,0x35,0x90,0xFA};
unsigned char IntToHexChar(unsigned char c)
{
if (c > 9)
return (c + 55);
else
return (c + 0x30);
}
int main()
{
unsigned char temp;
int i;
for (i=0; i<length; i++)
{
temp = s_src[i]&0xf0;
s_des[2*i] = IntToHexChar(temp >> 4);
temp = s_src[i]&0x0f;
s_des[2*i+1] = IntToHexChar(temp);
}
printf("*** %s *** ",s_des);
return 0;
}
(3)c語言十六進制轉字元串擴展閱讀:
十六進製表示方式
不同電腦系統、編程語言對於16進制數值有不同的表示方式:
Ada與VHDL用所基於的「數字引證」把16進制數包起來,例如「16#5A3#」。(注:Ada對整數和實數都可以使用從1到16中任何一個做為其基數。)而對於位元組向量,VHDL使用字首x表示,例如,x"10",對應的二進制碼為:"00010000"。
C語言、C++、Shell、Python、Java語言及其他相近的語言使用字首「0x」,例如「0x5A3」。開頭的「0」令解析器更易辨認數,而「x」則代表十六進制(就如「O」代表八進制)。在「0x」中的「x」可以大寫或小寫。對於字元量C語言中則以x+兩位十六進制數的方式表示,如xFF。
十六進制轉義序列:如x1abf4,可以使用任意多的十六進制數字,直至不是十六進制數字為止;
16位的通用字元名(universe-character name):u後面必須跟4個十六進制數字(不足四位前面用零補齊),表示Unicode中在0至0xFFFF之內的碼位(但不能表示0xD800到0xDFFF之內的碼點,Unicode標准規定這個范圍內的碼位保留,不表示字元);
32位的通用字元名:U後面必須跟8個十六進制數字(不足八位前面用零補齊),表示Unicode中所有可能的碼位(除0xD800到0xDFFF之外)。
C++11引進了十六進制浮點型字面常量。例如:0x1.2p10表示(1+2/16)×2=115210。實際上,Visual C++一直以來使用的C/C++語言標准庫函數printf,%a作為類型說明符來格式化輸出浮點型值即為上述格式。例如:printf("%a",1152.0);
C/C++在表示字元型字面常量時,可以用:
在VB、MSX BASIC、Quick BASIC和FreeBASIC中,使用字首「&H」來表示。
在HTML,十六進制字元可以用「x」,例如֣和֣效果應該無異。
Intel的匯編語言中用字尾「h」來標識16進位的數(若該數以字母起首,在前面會增加一個「0」)例如「0A3Ch」、「5A3h」
其他匯編器(AT&T、Motorola、6502),Pascal,Delphi和某些BASIC的版本使用字首「$」,例如「$5A3」
亦有用X'5A3'這類表示方式的,如於PL/I,COBOL及JCL中。這亦是IBM裝載早期操作系統的大型機與小型機上最常用的數據格式。
由於表示方式沒有單一、已協定的標准,所以以上的表示方式都有被使用,有時甚至在同一份論文上會出現幾個不同的表示方式。但因為各方式之間沒有太大的分歧,所以即使混合使用也沒有構成問題。
其中最常用(或常見)表示十六進制數值的方式是將'0x'加在數字前,或在數字後加上小字16。例如0x2BAD和2BAD16都是表示十進制的11181(或1118110)。
在網頁設計上十六進制是很常用的。HTML和CSS使用十六進制的表示法來表示網頁上的特定顏色。使用#的符號來表示而非用個別的符號表示十六進制。
24-bit顏色可以用#RRGGBB的格式來表示,RR是顏色中紅色成分的數值,GG是顏色中綠色成分的數值,BB顏色中藍色成分的數值。舉個例子,紅色的陰影是十進制238,9,63可以編成#EE093F。
4. C語言 如何將16進制形式的字元串,轉化為相同的16進制的整型
如何將16進制形式的字元串,轉化為相同的16進制的整型,這個問題,如果是在輸出端而言,這本身是不存在的問題。因為要輸出十六進制的數,本身就是輸出一個字元串,完全不需要轉換的。
如果是要轉換為在計算機內存儲的變數的值,則是提問者對計算機的原理不理解。計算機中所有的數都是以二進制形式存儲,才能直接進行計算的。如果是要把十六進制的字元串,轉換為數值形式,實際上是轉換為十進制值(計算機以二進制存儲,十六進制形式是程序員為簡便而產生的,它是二進製表示的另一種形式),可以以下面的代碼實現:
int str2int(char s[])
{int i,f;
for(i=f=0;s[i];i++)
if(s[i]>='0'&&s[i]<='9')f=f*16+s[i]-'0';
else if(s[i]>='a'&&s[i]<='f')f=f*16+s[i]-87;
else if(s[i]>='A'&&s[i]<='F')f=f*16+s[i]-55;
else return f;
}