Tag Archives: SimpleDateFormat

[Java/Android] 안드로이드 특정기기에서 발생하는 SimpleDateFormat 버그

안드로이드에서 시간을 표기해 줄때 다양한 포맷으로 변경을 하기 위해 SimpleDateFormat을 활용하였습니다. 하지만 여기서 생각치도 못한 버그가 있었습니다. 회사에서 가지고 있는 몇몇 디바이스들로 테스트 해본 결과 특정 기기에서만 발생하는 것을 확인하였습니다. (예: LG 거의 모든 제품)

아이폰 개발을 처음할 당시에 아이폰이 없어서 아이팟 터치만으로 개발하고 전세계 앱스토어에 런칭을 했을때 모두들 잘된다는 피드백이 오던 시절과는 너무도 다른 안드로이드의 현실에 조금은 답답해지는 순간입니다. 왜 안드로이드는 기기마다 다를까요.

public class DateFormatUtilActivity extends Activity
{
    private TextView mTextView;

    @Override
    public void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        mTextView = (TextView) findViewById(R.id.textView);

        StringBuffer sb = new StringBuffer();
        sb.append("1900-01-01 00:00:00 / ");// 1900-01-01 00:00:00
        sb.append(fomattedDate(new Date(0, 0, 1, 0, 0, 0)));
        sb.append("\n");
        sb.append("1901-01-01 00:00:00 / ");// 1901-01-01 00:00:00
        sb.append(fomattedDate(new Date(1, 0, 1, 0, 0, 0)));
        sb.append("\n");
        sb.append("1902-01-01 00:00:00 / ");// 1902-01-01 00:00:00
        sb.append(fomattedDate(new Date(2, 0, 1, 0, 0, 0)));
        sb.append("\n");
        sb.append("1912-01-01 00:00:00 / ");// 1912-01-01 00:00:00
        sb.append(fomattedDate(new Date(12, 0, 1, 0, 0, 0)));
        sb.append("\n");
        sb.append("1913-01-01 00:00:00 / ");// 1913-01-01 00:00:00
        sb.append(fomattedDate(new Date(13, 0, 1, 0, 0, 0)));
        sb.append("\n");
        sb.append("1980-01-01 00:00:00 / ");// 1980-01-01 00:00:00
        sb.append(fomattedDate(new Date(80, 0, 1, 0, 0, 0)));
        sb.append("\n");
        sb.append("1990-01-01 00:00:00 / ");// 1990-01-01 00:00:00
        sb.append(fomattedDate(new Date(90, 0, 1, 0, 0, 0)));
        sb.append("\n");
        sb.append("2000-01-01 00:00:00 / ");// 2000-01-01 00:00:00
        sb.append(fomattedDate(new Date(100, 0, 1, 0, 0, 0)));
        sb.append("\n");
        sb.append("2001-01-01 00:00:00 / ");// 2001-01-01 00:00:00
        sb.append(fomattedDate(new Date(101, 0, 1, 0, 0, 0)));

        mTextView.setText(sb.toString());
    }

    public String fomattedDate(Date fromDate)
    {

    String format = "yyyy년 MM월 dd일 HH:mm:ss";
    SimpleDateFormat toFormat = new SimpleDateFormat(format);
return toFormat.format(fromDate);
    }
}

위와 같은 소스를 실행해 보았습니다. 위의 소스는 1900년도부터 2001년까지의 1월1일 0시를 출력하는 몇가지 예제 소스입니다. 주석으로 붙여둔 부분의 값이 그대로 나와야 정상입니다. 우선 제가 가지고 있는 모토글램으로 테스트를 해보겠습니다.

사용자 삽입 이미지

왼쪽과 오른쪽이 동일하면 정상입니다. 모토글램의 경우 매우 정상이네요. 다음은 LG의 견인차 역할을 한 옵티머스원입니다.

사용자 삽입 이미지

한번 천천히 살펴보겠습니다. 1900년도의 날짜와 시간표기에는 아무런 문제가 없습니다. 하지만 1902년부터 시간이 -47분40초가 됩니다. 그러더니 1913년부터는 아예 -1시간이 되는군요. 정말 신기한 현상입니다. 더신기한건 2001년부터 날짜표기 오류가 정상으로 돌아옵니다.

우선 대부분의 안드로이드폰에서는 이런 문제가 발생하지 않습니다. 날짜와 시간을 중요하는 어플리케이션을 개발중이시라면 SimpleDateFormat의 사용을 자제하시기 바랍니다. 기기특성을 타는 문제가 있습니다.