0

我想确保我真正理解使用 .toUpperCase 时发生的事情。这是一段运行良好的代码。我只想知道我的评论是否正确描述了正在发生的事情。

char first = 'j';   //Declare char variable & initialize it's value: j

/* toUpperCase method of the Character Class Wrapper is invoked
 * char primitives are autoboxed to Character Objects
 * toUpperCase method unboxes the converted Characters to char primitives
 */

char firstUp = Character.toUpperCase(first);

感谢大家以简单和非常详细的答案做出回应。非常感激。

4

3 回答 3

2

不,请参阅http://docs.oracle.com/javase/7/docs/api/java/lang/Character.html。的签名toUpperCase

public static char toUpperCase(char ch)

换句话说,一个char进去,一个char出来。在您的示例中,根本没有自动装箱或自动拆箱。

于 2013-11-08T02:00:30.683 回答
1

除了其他答案,源代码:

字符.java

public static char toUpperCase(char ch) {
    return (char)toUpperCase((int)ch);
}

public static int toUpperCase(int codePoint) {
    return CharacterData.of(codePoint).toUpperCase(codePoint);
}

字符数据.java

static final CharacterData of(int ch) {
    if (ch >>> 8 == 0) {     // fast-path
        return CharacterDataLatin1.instance;
    } else {
        switch(ch >>> 16) {  //plane 00-16
        case(0):
            return CharacterData00.instance;
        case(1):
            return CharacterData01.instance;
        case(2):
            return CharacterData02.instance;
        case(14):
            return CharacterData0E.instance;
        case(15):   // Private Use
        case(16):   // Private Use
            return CharacterDataPrivateUse.instance;
        default:
            return CharacterDataUndefined.instance;
        }
    }
}

CharacterData00.java(例如)

int toUpperCase(int ch) {
    int mapChar = ch;
    int val = getProperties(ch);

    if ((val & 0x00010000) != 0) {
      if ((val & 0x07FC0000) == 0x07FC0000) {
        switch(ch) {
          // map chars with overflow offsets
        case 0x00B5 : mapChar = 0x039C; break;
        case 0x017F : mapChar = 0x0053; break;
        case 0x1FBE : mapChar = 0x0399; break;
          // map char that have both a 1:1 and 1:M map
        case 0x1F80 : mapChar = 0x1F88; break;
        case 0x1F81 : mapChar = 0x1F89; break;
        case 0x1F82 : mapChar = 0x1F8A; break;
        case 0x1F83 : mapChar = 0x1F8B; break;
        case 0x1F84 : mapChar = 0x1F8C; break;
        case 0x1F85 : mapChar = 0x1F8D; break;
        case 0x1F86 : mapChar = 0x1F8E; break;
        // Many more
       }
      }
      else {
        int offset = val  << 5 >> (5+18);
        mapChar =  ch - offset;
      }
    }
    return mapChar;
}

如您所见:绝不会发生装箱/拆箱。

于 2013-11-08T02:06:53.037 回答
0

内部toUpperCase使用CharacterData它的子类(包私有)来查找从小写字符到其大写对应字符的映射。

事实上,大多数内部操作都是使用int变量完成的。转换中不涉及任何包装器类型。

于 2013-11-08T02:08:32.223 回答