如何将char类型的数字字符转换成int类型问题

 更新时间:2022年12月23日 08:48:30   作者:幸运草铃兰  
这篇文章主要介绍了如何将char类型的数字字符转换成int类型问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

将char类型的数字字符转换成int类型

近来面试遇到一个问题,通过控制台输入一个12位的数字,然后进行一些计算,然后被困在如何把char类型的数字转换成int类型。

通过搜索,找到两个解决办法。

1、把char型转换成int类型

 for(int i = 0;i<str.length();i++)
    {
        char temp_char = str.charAt(i);
        //把字符转换成数字方法一
       int temp_int = temp_char-'0';
       //把字符转换成数字方法二
       int temp_int = Integer.parseInt(String.valueOf(temp_char));
 
      }

第一种办法:通过charAt(i),把字符串的每位变成char型,然后用当前字符减去字符0 (temp_char-'0'),得到当前字符的int值。

第二种办法:把字符再转成字符串,然后再强制转换成int型。

2、把字符串拆分成一位一位的

第一种方法:循环后charAt(i);

注意:charAt(i)得到的是字符串对应的每位字符,可是不能直接转成int,转成int依然是ASCII值。

第二种方法:char[] temp = str.toCharArray();  

注意:char[]里的内容不是字符串的每位字符,而是每位字符的ASCII值。

具体面试题如下:

package cjl;
 
import java.util.Scanner;
 
/**
 * 一维码有一种编码是ean13,是一串13位数字。其中第13位是校验码,作用是校验前面12个数字是否正确。
 * 校验方法如下:
 * 1、前12位数字从左起,将所有的奇数位相加得出一个数a,将所有的偶数位相加得出一个数b
 * 2、将数b乘以3再与a相加得到数c
 * 3、用10减去数c的个位数,如果结果不为10则校验码为结果本身,如果为10则校验码为0
 * 请在控制台任意输入一个12位数字,然后输出校验码
 * @author ff
 *
 */
 
 
public class CheckCode {
    
    public void checkCode(String str)
    {
        int checkCode = 0;
            int a = 0;//奇数位的和
            int b = 0;//偶数位的和
            for(int i = 0;i<str.length();i++)
            {
                char temp_char = str.charAt(i);
                //把字符转换成数字方法一
                int temp_int = temp_char-'0';
                //把字符转换成数字方法二
                //int temp_int = Integer.parseInt(String.valueOf(temp_char));
                //System.out.println("temp_char = "+temp_char);
                //System.out.println("temp__int = "+temp_int);
                if((i+1)%2==0)//偶数位
                {
                    b+=(int)temp_int;
                }
                else //奇数位
                {
                    a = a+(int)temp_int;
                }
                
            }
            int c = a+b*3;
            int c_gw = c%10;
            int d = 10-c_gw;
            
            //System.out.println("a = "+a+" b = "+b+" c = "+c+" c_gw = "+c_gw+" d = "+d);
            if(d==10)
            {
                checkCode= 0;
            }
            else
            {
                checkCode= d;
            }
        
            System.out.println("checkCode = "+checkCode);
    }
    
    public void Input()
    {
        while (true) {
            Scanner scanner = new Scanner(System.in);
            System.out.println("请输入一个12位的数字。。。。。。");
            String str = scanner.nextLine();
            if((str.length()==12)&&(str.matches("[0-9]+")))
            {
                checkCode(str);
                break;
            }
        }
    }
    
    /**
     * @param args
     */
    public static void main(String[] args) {
        
        CheckCode codeVo = new CheckCode();
        codeVo.Input();
    }
 
 
}

运行结果:

请输入一个12位的数字。。。。。。
111111111111
checkCode = 6

两个char类型的字符相加结果是int类型的整数

程序验证

public class Test {
    public static void main(String[] args) {
        System.out.println('a'+'b');
    }
}

结果:

195

结论

当对byte、short、char类型进行混合运算时,最终结果一定是整型,当然你也可以把它们都转换成int类型的,之后在进行混合运算

当多种数据类型进行混合运算的时候,最后的数据类型一定是它们中取值最大的那个数据类型,如果里面有字符串的话,那最后的数据类型一定是字符串类型,至于中间怎么运算的,接下来我通过几个例子来说明一下:

例1:

public class Test {
    public static void main(String[] args) {
        System.out.println(1 / 2 + 1.1);
        System.out.println(1.0 / 2 + 1.1);
    }
}

结果:

1.1
1.6

解释:

如果没有直接和1.1相加运算,那1/2还是按照整型去计算的,计算结果是0,然后加上1.1,结果就是double类型的;

如果计算的过程中直接就是1.0/2,那结果就是0.5,之后和1.1相加那结果就是1.6,结果还是double

例2:

public class Node {
    public static void main(String[] args) {
        System.out.println(1 + 2 + "3");
        System.out.println("1" + 2 + 3);
    }
}

结果:

33
123

解释:

通过第一个结果可以看出是先进行1+2,得出结果是3,之后在和字符串3拼接,所以结果是字符串33;

然后看第二个结果,那就是字符串1和2拼接,结果是字符串12,然后字符串12和3拼接,结果就是字符串123;

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Java concurrency线程池之线程池原理(二)_动力节点Java学院整理

    Java concurrency线程池之线程池原理(二)_动力节点Java学院整理

    这篇文章主要为大家详细介绍了Java concurrency线程池之线程池原理第二篇,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-06-06
  • Eureka源码核心类预备知识

    Eureka源码核心类预备知识

    这篇文章主要为大家介绍了Eureka源码核心类预备知识详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • 深入理解Java设计模式之简单工厂模式

    深入理解Java设计模式之简单工厂模式

    这篇文章主要介绍了JAVA设计模式之简单工厂模式的的相关资料,文中示例代码非常详细,供大家参考和学习,感兴趣的朋友可以了解下
    2021-11-11
  • Spring JPA联表查询之OneToOne源码详解

    Spring JPA联表查询之OneToOne源码详解

    这篇文章主要为大家介绍了Spring JPA联表查询之OneToOne源码详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-04-04
  • java解决单缓冲生产者消费者问题示例

    java解决单缓冲生产者消费者问题示例

    这篇文章主要介绍了java解单缓冲生产者消费者问题示例,需要的朋友可以参考下
    2014-04-04
  • Mybatis整合Spring 由于版本引起的BUG问题

    Mybatis整合Spring 由于版本引起的BUG问题

    这篇文章主要介绍了Mybatis整合Spring 由于版本引起的BUG问题,需要的朋友可以参考下
    2017-06-06
  • Java后端接入微信小程序登录功能(登录流程)

    Java后端接入微信小程序登录功能(登录流程)

    这篇文章主要介绍了Java后端接入微信小程序登录功能,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-06-06
  • Resty开发restful版本的Jfinal深入研究

    Resty开发restful版本的Jfinal深入研究

    这篇文章主要为大家介绍了Resty开发restful版本的Jfinal深入研究有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-03-03
  • MyBatis 超详细讲解动态SQL的实现

    MyBatis 超详细讲解动态SQL的实现

    动态 SQL 是 MyBatis 的强大特性之一。如果你使用过 JDBC 或其它类似的框架,你应该能理解根据不同条件拼接 SQL 语句有多痛苦,例如拼接时要确保不能忘记添加必要的空格,还要注意去掉列表最后一个列名的逗号。利用动态 SQL,可以彻底摆脱这种痛苦
    2022-03-03
  • Java Morris遍历算法及其在二叉树中的应用

    Java Morris遍历算法及其在二叉树中的应用

    Morris遍历是一种基于线索二叉树的遍历算法,可以在不使用栈或递归的情况下,实现二叉树的前序、中序和后序遍历。该算法利用二叉树中的空指针或线索指针,将遍历序列嵌入到原二叉树中,实现了常数级别的空间复杂度,适用于对空间要求较高的场景
    2023-04-04

最新评论