十六进制转换为十进制的效率问题
生活随笔
收集整理的這篇文章主要介紹了
十六进制转换为十进制的效率问题
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
? ? ? ? ? ? ? ? ? 十六進制轉(zhuǎn)換為十進制這樣說有點籠統(tǒng),因為一般來說十六進制是字符串,十進制也可能是字符串或是整數(shù)。下面我們來看看。
1.十六進制字符串轉(zhuǎn)換為十進制的字符串
?
#include<stdio.h>int main() {char str1[10]="32";//十六進制char str2[10]={0};//十進制sscanf(str1,"%02X",str2);printf("str2=%s\n",str2);return 0; }打印:str2=2
?
?
另一種方法:
?
#include <stdio.h> #include <string.h> #include <stdlib.h>int hexCharToValue(const char ch)//求字符串對應(yīng)的偏移量 {int result = 0;if(ch >= '0' && ch <= '9'){result = (int)(ch - '0');}else if(ch >= 'a' && ch <= 'z'){result = (int)(ch - 'a') + 10;}else if(ch >= 'A' && ch <= 'Z'){result = (int)(ch - 'A') + 10;}else{result = -1;}return result; }int hexToStr(char *hex, char *ch) {int high,low;int tmp = 0;if(hex == NULL || ch == NULL){return -1;}if(strlen(hex) %2 == 1){return -2;}while(*hex){high = hexCharToValue(*hex);//高位if(high < 0){*ch = '\0';return -3;}hex++; //指針移動到下一個字符上low = hexCharToValue(*hex);//地位if(low < 0){*ch = '\0';return -3;}tmp = (high << 4) + low;*ch++ = (char)tmp;hex++;}*ch = '\0';return 0; }int main(int argc, char *argv[]) {char *p_hex = "32";//十六進制char p_result[20] = {0};//十進制hexToStr(p_hex, p_result); printf("%s\n", p_result);system("pause");return 0; }打印:2
?
這兩種方式都能解決問題,很明顯第二種看起來復(fù)雜的多,但是實際用起來,第二種方法比第一種方法高效。實際工作中我解密的時候就碰到過這種情況,然后換了第二種方法。
?
2.十六進制字符串轉(zhuǎn)換成十進制整形
?
#include<stdio.h>int main() {char str1[10]="32";//十六進制int a=0; //十進制sscanf(str1,"%02X",&a);printf("a=%d\n",a);return 0; }打印:a=50
?
這個也可以用第二種方法,稍微變幻一下就行了。
十進制轉(zhuǎn)十六進制用sprintf用的多,這個大家可以試一下。十六進制作為整數(shù)轉(zhuǎn)十進制字符串到?jīng)]怎么遇到過,十六進制整數(shù)轉(zhuǎn)十進制數(shù)就不說了。主要還是sscanf效率低。
?
?
?
參考地址:
http://blog.csdn.net/stpeace/article/details/13168851
http://blog.chinaunix.net/uid-20680669-id-3157274.html
?
?
?
?
?
?
?
?
總結(jié)
以上是生活随笔為你收集整理的十六进制转换为十进制的效率问题的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: linux下的strerror和perr
- 下一篇: 利用curl命令测试服务端