Getting empty character literal error in java code that specified unicode literals [duplicate]

StackOverflow https://stackoverflow.com/questions/21191928

  •  29-09-2022
  •  | 
  •  

문제

Why does this code

 public class Apostrophier
{
    public static String replace(String s)
    {
        return s.replace('\u0092','\u0027');
    }
}

give

'empty character literal'

when I try to compile ?

도움이 되었습니까?

해결책

The unicode code points in the source file are replaced by the actual character they represents. Since '\u0027' is for ' (apostrophe). So, your return statement is replaced to:

  return s.replace('\u0092',''');  

Note: \u0092 will also be replaced by control character.

So, the 2nd argument is an invalid character literal. You can rather use \' directly.

다른 팁

Replacing the unicode sequences is a very early step of the compilation process. In particular, it happens before parsing literals. So when it's time to parse the literals, \u0027 has already been replaced with '. Therefore, after the comma, you have ''', which the compiler can't make sense of.

라이센스 : CC-BY-SA ~와 함께 속성
제휴하지 않습니다 StackOverflow
scroll top