市场人员反映公司的app使用系统设置俄语、西班牙语,double数据会把小数点变为逗号。调试一下,是自定义的语言时候(例如,俄语、西班牙语)转换String.format("%.2f",67.876)。会出现的。

1、android 系统,设置系统语言的步骤

Android【设置】-【语言和输入法】-【语言】列表中找到相应语言所对应的列表项

2、问题分析

java.util.Locale类

在这个Locale类里面,有些语言是没有,例如俄语、西班牙语等。那么这时候android开发时候需要这些语言,怎么办。只好后面自已新建,自定义。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
/**
 * Locale constant for en_CA.
 */
public static final Locale CANADA = new Locale(true, "en", "CA");
 
/**
 * Locale constant for fr_CA.
 */
public static final Locale CANADA_FRENCH = new Locale(true, "fr", "CA");
 
/**
 * Locale constant for zh_CN.
 */
public static final Locale CHINA = new Locale(true, "zh", "CN");
 
/**
 * Locale constant for zh.
 */
public static final Locale CHINESE = new Locale(true, "zh", "");
 
/**
 * Locale constant for en.
 */
public static final Locale ENGLISH = new Locale(true, "en", "");

Locale类里面,私有方法新建语言的。可是不提供外部调用。

1
2
3
4
5
6
7
8
9
10
11
12
/**
     * There's a circular dependency between toLowerCase/toUpperCase and
     * Locale.US. Work around this by avoiding these methods when constructing
     * the built-in locales.
     *
     * @param unused required for this constructor to have a unique signature
     */
    private Locale(boolean unused, String lowerCaseLanguageCode, String upperCaseCountryCode) {
        this.languageCode = lowerCaseLanguageCode;
        this.countryCode = upperCaseCountryCode;
        this.variantCode = "";
    }

源码中的这个方法是共外部新建语言的。
构造一个新的{ @code地区}使用指定的语言,国家,和变体编码。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
/**
 * Constructs a new {@code Locale} using the specified language, country,
 * and variant codes.
 */
public Locale(String language, String country, String variant) {
    if (language == null || country == null || variant == null) {
        throw new NullPointerException();
    }
    if (language.isEmpty() && country.isEmpty()) {
        languageCode = "";
        countryCode = "";
        variantCode = variant;
        return;
    }
 
    languageCode = language.toLowerCase(Locale.US);
    // Map new language codes to the obsolete language
    // codes so the correct resource bundles will be used.
    if (languageCode.equals("he")) {
        languageCode = "iw";
    } else if (languageCode.equals("id")) {
        languageCode = "in";
    } else if (languageCode.equals("yi")) {
        languageCode = "ji";
    }
 
    countryCode = country.toUpperCase(Locale.US);
 
    // Work around for be compatible with RI
    variantCode = variant;
}
 
@Override public Object clone() {
    try {
        return super.clone();
    } catch (CloneNotSupportedException e) {
        throw new AssertionError(e);
    }
}

这是我在外面新建俄语、西班牙语。因为调用不了上面是有方法。只有这个方法。
这个方法的新建是为了匹配资源文件的翻译的以及后面的系统的调用

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
private static final Locale Locale_Russia = new Locale("RUS", "ru", "");
    private static final Locale Locale_Spanish = new Locale("ES", "es", "");
    public static void setApplicationLauguageType(Context context, int type) {
        if (context == null) return;
        Resources resources = context.getResources();//获得res资源对象
        Configuration config = resources.getConfiguration();//获得设置对象
        DisplayMetrics dm = resources .getDisplayMetrics();//获得屏幕参数:主要是分辨率,像素等。
         
        switch (type) {
        case 0:
            config.locale = Locale.getDefault();
            break;
        case 1:
            config.locale = Locale.SIMPLIFIED_CHINESE;
            break;
        case 2:
            config.locale = Locale.ENGLISH;
            break;
        case 3:
            config.locale = Locale_Russia;
            break;
        case 4:
            config.locale = Locale_Spanish;
            break;
        default:
            config.locale = Locale.getDefault();
            break;
        }
         
        resources.updateConfiguration(config, dm);
    }
1
2
3
4
5
/**
     * Returns a localized formatted string, using the supplied format and arguments,
     * using the user's default locale.
     *
     *

If you're formatting a string other than for human * consumption, you should use the {@code format(Locale, String, Object...)} * overload and supply {@code Locale.US}. See * "Be wary of the default locale". * * @param format the format string (see {@link java.util.Formatter#format}) * @param args * the list of arguments passed to the formatter. If there are * more arguments than required by {@code format}, * additional arguments are ignored. * @return the formatted string. * @throws NullPointerException if {@code format == null} * @throws java.util.IllegalFormatException * if the format is invalid. * @since 1.5 */ public static String format(String format, Object... args) { return format(Locale.getDefault(), format, args); }

这上面是一般调用方法,String strResult = String.format("%0.2f",543.6356);
这句语句是double型543.6356保留小数点的两位,并转化成String类型。
调用这个方法时候,其实是默认调用format(Locale.getDefault(), format, args)。因为返回是调用了这个。多了一个参数就是Locale.getDefault()。这个参数使获取系统设置的语言。并作为后面的转换参数的。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
/**
  * Returns a formatted string, using the supplied format and arguments,
  * localized to the given locale.
  *
  * @param locale
  *            the locale to apply; {@code null} value means no localization.
  * @param format the format string (see {@link java.util.Formatter#format})
  * @param args
  *            the list of arguments passed to the formatter. If there are
  *            more arguments than required by {@code format},
  *            additional arguments are ignored.
  * @return the formatted string.
  * @throws NullPointerException if {@code format == null}
  * @throws java.util.IllegalFormatException
  *             if the format is invalid.
  * @since 1.5
  */
 public static String format(Locale locale, String format, Object... args) {
     if (format == null) {
         throw new NullPointerException("format == null");
     }
     int bufferSize = format.length() + (args == null ? 0 : args.length * 10);
     Formatter f = new Formatter(new StringBuilder(bufferSize), locale);
     return f.format(format, args).toString();
 }

那么现在问题就来了。但我使用自定义的语言时候(例如,俄语、西班牙语)。使用下面语句转换,小数点会变成逗号

1
2
double dValue = 360.672;
String strValue = String.format("%.2f",dValue);

结果360,672

如果我使用Locale类有定义,就不会出现这种情况。例如中文,英文肯定是正常的。

3、解决办法

分析到这里了,就说一下解决办法。
只好调用这个方法String.format(Locale.ENGLISH,"%.2f",dValue),多了一个参数。自已传进去转换的语言是什么。不再是默认系统语言设置的。因为对于数据,全世界都是通用,那么默认使用英语来转换都没有问题。数据都是这样转换的。

1
2
double dValue = 360.672;
String strValue = String.format(Locale.ENGLISH,"%.2f",dValue);

那么又产生一个问题,同时有转换字符串。这个得注意一下。

1
String strResult = String.format("%s:%.3f\r\n", getString(R.string.IteInfoCoorType, 654.76);

这个就要分开转换再接起来,不然都是英文,转换不了其他的语言的。

这个设计上缺陷是否是android sdk 或者jdk的存在bug。我使用都是jdk1.7和sdk 4.2版本。
欢迎大家发现与测试。

1
2
String.format("%.2f",dValue);
String.format(Locale.ENGLISH,"%.2f",dValue);

android 使用String.format("%.2f",67.876)自已定义语言(俄语、西班牙语)会把小数点变为逗号的更多相关文章

  1. 我的Android进阶之旅------>Java字符串格式化方法String.format()格式化float型时小数点变成逗号问题

    今天接到一个波兰的客户说有个APP在英文状态下一切运行正常,但是当系统语言切换到波兰语言的时候,程序奔溃了.好吧,又是我来维护. 好吧,先把系统语言切换到波兰语,切换到波兰语的方法查看文章 我的And ...

  2. JAVA字符串格式化-String.format()的使用(转)

    常规类型的格式化 String类的format()方法用于创建格式化的字符串以及连接多个字符串对象.熟悉C语言的同学应该记得C语言的sprintf()方法,两者有类似之处.format()方法有两种重 ...

  3. Java字符串格式化String.format常用用法

    常规的格式化 String类的format()方法用于创建格式化的字符串以及连接多个字符串对象.熟悉C语言的同学应该记得C语言的sprintf()方法,两者有类似之处.format()方法有两种重载形 ...

  4. String.format(转)

    转自:http://blog.csdn.net/lonely_fireworks/article/details/7962171 方便自己查阅. 常规类型的格式化 String类的format()方法 ...

  5. JAVA字符串格式化String.format()的使用

    JAVA字符串格式化-String.format()的使用常规类型的格式化 String类的format()方法用于创建格式化的字符串以及连接多个字符串对象.熟悉C语言的同学应该记得C语言的sprin ...

  6. JAVA字符串格式化-String.format()的使用 (转载)

    常规类型的格式化 String类的format()方法用于创建格式化的字符串以及连接多个字符串对象.熟悉C语言的同学应该记得C语言的sprintf()方法,两者有类似之处.format()方法有两种重 ...

  7. 【转】JAVA字符串格式化-String.format()的使用--不错

    原文网址:http://blog.csdn.net/lonely_fireworks/article/details/7962171 常规类型的格式化 String类的format()方法用于创建格式 ...

  8. 【转】JAVA字符串格式化-String.format()的使用

    原文网址:http://blog.csdn.net/lonely_fireworks/article/details/7962171 常规类型的格式化 String类的format()方法用于创建格式 ...

  9. java String.Format详解

    JDK1.5中,String类新增了一个很有用的静态方法String.format(): format(Locale l, String format, Object... args) 使用指定的语言 ...

随机推荐

  1. class-loader.

    the jdk hierarchical relationship of class-loader ----Module Class Loading and Bootstrapping---- boo ...

  2. SQL 中的好习惯和坏习惯

    在程序员日常的工作中,SQL可以说不可避免的,高效的SQL可以带来更加愉悦的体验.好的SQL书写习惯会给我们的工作带来极大的好处.简单总结下SQL的好习惯和坏习惯. IN和NOT IN 操作符 编码中 ...

  3. POJ3658Matrix( 双重二分+负数+死循环)

    POJ 3658 Matrix 双重二分,wa了一下午,实在不太明白为啥一写二分就会进入死循环. INF要设的大一些,本题设0x3f3f3f3f会wa. 本题有负数, 二分时(l+r)/2与(l+r) ...

  4. 你好,C++(9)坐216路公交车去买3.5元一斤的西红柿——C++中如何表达各种数值数据 3.3 数值数据类型

    3.3  数值数据类型 从每天早上睁开眼睛的那一刻开始,我们几乎每时每刻都在与数字打交道:从闹钟上的6点30分,到上班坐的216路公共汽车:从新闻中说的房价跌到了100元每平米到回家买菜时的西红柿3. ...

  5. 动态加载下拉框列表并添加onclick事件

    1.  js动态加载元素并设置属性 摘自(http://www.liangshunet.com/ca/201408/336848696.htm) <div id="parent&quo ...

  6. 34 Search for a Range(目标数的范围Medium)

    题目意思:递增数组,找到目标数的范围,找不到则返回[-1,-1] 思路:折半查找 class Solution { public: vector<int> searchRange(vect ...

  7. Ubuntu16.04下编译vim with python support失败的原因

    - youcompleteme原话:On Ubuntu 16.04, Python support was not working due to enabling both Python2 and P ...

  8. 使用django-mssql时候报pythoncom模块不存在

    pip install django-mssql是链接sqlserver的数据库db引擎,这里用到了pythoncom模块,所以还需要安装 pip install pypiwin32 settings ...

  9. .NET MVC插件化开发框架源码(插件功能完善版)

    离上次第一次上传源码一个多星期了,在工作之余今天终于把插件管理部门的功能全部完善了,已可用于实际开发,管理界面因为没人帮忙设计,所以有点丑,今天这版算是0.1.0.0吧,后面我会发布很多插件来填充这个 ...

  10. Autoit实现分割字符串,循环输出元素

    #include <MsgBoxConstants.au3> Local $aDays = StringSplit("Mon,Tues,Wed,Thur,Fri,Sat,Sun& ...