char类型转换成int_char 转int

char类型转换成int_char 转int字符串“1121“转换成整型1121#include<stdio.h>#include<string.h>voidCharToInt(int*dest,char*src,longlen);intmain(void){unsignedchar*str=”1121″;intvalue,str_len…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

字符串“1121“转换成整型1121

#include <stdio.h>
#include <string.h>

void CharToInt(int *dest, char *src, long len);

int main(void)
{ 
   
        unsigned char *str = "1121";
        int value, str_len;

        str_len = strlen(str);
        CharToInt(&value,str,str_len);
        printf("%d\n",value);
}
/*转换后数值的地址,传入的字符串,字符串长度*/
void CharToInt(int *dest, char *src, long len)
{ 
   
        int i;
        int value_temp = 0;

        for(i=0;i<len;i++)
        { 
   
                value_temp = value_temp*10 + (*(src+i)-'0');
        }
        *dest = value_temp;
}
/*运行*/
1121

一个寄存器(2个字节)存储的数据转换成int型(0x1121 -> ???)

注:重要的一点,要判断高字节在前还是低字节在前。

#include <stdio.h>

#define HIGH 0
#define LOW 1

void CharToInt(int *, char *, long , int );

int main(void)
{ 
   
        unsigned char str[] = { 
   0x11,0x21};
        int value, str_len;

        str_len = sizeof(str);
        CharToInt(&value,str,str_len,HIGH);
        printf("%d\n",value);
}
/*转换后数值的地址,传入的字符串,字节个数,高或低字节在前*/
void CharToInt(int *dest, char *src, long len, int highlow)
{ 
   
        int i, j;
        int value_temp = 0;

        if(highlow == HIGH)
        { 
   
                j = len-1;
                for(i=0;i<len;i++)
                { 
   
                        value_temp |= ((*(src+i))&0xff)<<(8*j); 
                        j--;
                }
        }
        else
        { 
   
                for(i=0;i<len;i++)
                { 
   
                        value_temp |= ((*(src+i))&0xff)<<(8*i);
                }
        }
        *dest = value_temp;
}
/*运行*/
4385

填入十六进制0x1121进去,转换成十进制确实是4385
在这里插入图片描述在这里插入图片描述
!!!慢着,先别走,突然想到一个非常简单方便的方法。

#include <stdio.h>

union CharInt
{ 
   
        unsigned char str[2];
        short int value;
};

int main(void)
{ 
   
        union CharInt I;
        I.value = 0;
        I.str[1] = 0x11;
        I.str[0] = 0x21;

        printf("%d\n",I.value);
}
/*运行*/
4385

程序真的是极简啊,用联合类型有时候用来转换数据类型是非常方便实用的,其中的原理就是因为联合类型共用一个内存空间咯,但是要注意它是小端模式存储的,低字节对应低地址。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/188547.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • GSLB功能

    GSLB功能GSLB应为一个高效率的智能的DNS服务器,并且可以在基于负载均衡算法的基础上对定义好的域名进行解析。可从如下角度来分析GSLBDNS功能以及标准性对GSLB架构设计算法设计1.严格遵守DNS的相关标准。概括的说是性能优良,功能全面。做为负载均衡设备,性能始终是非常重要的。要能实习高负载大流量下对DNS请求的迅速应答。在功能实现方面DNS相关RFC(rfc1034,…

    2022年6月8日
    83
  • 彻底删除&quot;提示删除文件和目录&quot;时出错的文件或目录

    彻底删除&quot;提示删除文件和目录&quot;时出错的文件或目录

    2021年12月10日
    40
  • MySQL里有2000w数据,redis中只存20w的数据,如何保证redis中的数据都是热点数据?「建议收藏」

    MySQL里有2000w数据,redis中只存20w的数据,如何保证redis中的数据都是热点数据?

    2022年2月11日
    137
  • 线性代数攻略(适合复习考试,零基础不挂科秘籍)「建议收藏」

    线性代数攻略(适合复习考试,零基础不挂科秘籍)「建议收藏」前言1、考试保过,最低在70分以上,零基础,只要看了复习攻略或者答题模板,一定能过。前提是真的认真看了,也练习了。2、多看,把这上面的例题多练,要不考试的时候会忘了哪个题用哪个方法。一定一定要牢记,多看,有的题不要问原因,直接记过程即可。3、要抽出至少两天的时间认真看这套答题模板,否则挂科了补考可真的是会浪费时间,线代这么简单,一定不要挂!4、出题的顺序会变,但是类型基本不会变,掌握做题技巧就行。5、如果是学知识,建议别看了,还是认真去看书,本攻略只适合高效率的让你不挂科,只是提高分数,

    2025年6月13日
    3
  • 最短路径问题—Dijkstra算法详解

    最短路径问题—Dijkstra算法详解前言Nobodycangobackandstartanewbeginning,butanyonecanstarttodayandmakeanewending.Name:WillamTime:2017/3/81、最短路径问题介绍问题解释:从图中的某个顶点出发到达另外一个顶点的所经过的边的权重和最小的一条路径,称为最短路径解决问题的算法:…

    2022年6月4日
    30
  • 怎样修改hosts文件权限_修改host显示没有权限怎么办

    怎样修改hosts文件权限_修改host显示没有权限怎么办文章目录1.打开host文件2.右键属性->安全->高级3.更改->高级->立即查找4.在下拉菜单中找到”本地账户”确定->确定->应用5.出现弹窗->确定->确定6.编辑->选中组或用户名当中的”Users(DESKTOP-XXXXX\users)”->勾选Users的权限下的:允许完全控制->点应用->确定即可修改hosts文件了。1.打开host文件文件位置C:\Windows\System32\drivers\etc

    2022年10月12日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号