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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • ExecuteNonQuery()_sql存储过程返回值

    ExecuteNonQuery()_sql存储过程返回值本文实例讲述了C#中ExecuteNonQuery()返回值注意点。对于C#数据库程序设计有一定的借鉴价值。分享给大家供大家参考之用。具体分析如下:首先,在查询某个表中是否有数据的时候,我们通常用ExecuteNonQuery(),并通过判断值是否大于0来判断数据的存在与否。结果与我所设想的很不一致,调试时才发现,其执行后返回的结果是-1,对此我很是不理解,回头查了下资料,如下显示:SqlComm…

    2025年10月26日
    3
  • Java数组(二维数组)「建议收藏」

    Java数组(二维数组)「建议收藏」目录前言多维数组二维数组声明二维数组创建二维数组访问二维数组遍历二维数组最后前言在上一篇文章Java数组(一维数组)中,我们学习了一维数组,那么今天我们来学习Java二维数组。多维数组数组元素除了可以是原始数据类型、对象类型之外,还可以是数组,即数组元素是数组,通过声明数组的数组来实现多维数组。多维数组的使用和二维数组使用相似,我们来介绍二维数组。二维数组声明二维数组声明二维数组语法有两种格式,例如:数组类型[][]数组名;

    2022年7月7日
    24
  • (七十)Android O Service启动流程梳理——bindService

    (七十)Android O Service启动流程梳理——bindService前言:最近在处理anr问题的时候迫切需要搞清楚service的启动流程,抽时间梳理一下。1.service启动简述service启动分三种,比较简单的就是startService,AndroidO用于后台应用启动前台服务的startForegroundService和绑定服务的bindService。本篇继(六十四)AndroidOService启动流程梳理——startService 继续…

    2022年6月4日
    99
  • 渗透测试神器Nessus使用教程「建议收藏」

    渗透测试神器Nessus使用教程「建议收藏」简介:

    2022年10月19日
    5
  • 加密狗android,Android系统加密狗的设计与实现

    加密狗android,Android系统加密狗的设计与实现摘要:随着IT产业的迅猛发展,软件作为IT产业中的一项重要产品,现在已经随着电脑进入千家万户,深入到用户生活中的每个地方。但是针对软件,有一个问题一直存在,那就是软件盗版的问题。随着软件影响范围的扩大,盗版软件带来的危害也是越发的严重。另外,智能手机也已经进入一个高速发展期,Android系统手机在智能手机市场中占据很大的一块份额。在这样的背景下,本文提出一种使用Android系统手机对软件进行…

    2022年5月13日
    47
  • 哪个游戏盒子里有JAVA_关于点和盒子游戏的Java minimax

    哪个游戏盒子里有JAVA_关于点和盒子游戏的Java minimax我想建议您完全重新考虑代码.查看代码的问题(以及为什么这里没有很多响应)是很难遵循并且很难调试.例如,什么是gs.getRemainingLines,它究竟做了什么?(为什么剩下的线而不是所有合法的线?)但是,通过一些简化,可以更容易地弄清楚发生了什么并修复它.在抽象层面,minimax只是这个过程:floatminimax_max(GameStateg){if(gisterminal…

    2022年7月7日
    26

发表回复

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

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