안드로이드 프로젝트를 진행하면서, 아이디나 String 문자열등 저장해야 할 경우가 생깁니다. 보통의 경우 Data를 저장할 경우 DB를 써야하는데 DB를 쓰기에는 너무 간단하거나 애매한 상황이 생기기도 합니다. 그럴경우에 안드로이드에서 제공하는 SharedPreferences 를 사용하시기 바랍니다.


SharedPreferences는 해당 프로세스(어플리케이션)내에 File 형태로 Data를 저장해 줍니다. 그리고 해당 어플리케이션이 삭제되기 전까지 Data를 보관해 주는 기능을 합니다. (SharedPreferences 사용한 어플리케이션을 지우면 내용이 모두 삭제 됩니다. File이 삭제되는 것이지요.) 자 그럼 사용 방법에 대해 알아 보겠습니다.


import android.app.Activity;
import android.content.SharedPreferences;
import android.os.Bundle;

public class TestSharedPreferencesActivity extends Activity {
         @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);            
}
         // 값 불러오기
    private void getPreferences(){
        SharedPreferences pref = getSharedPreferences("pref", MODE_PRIVATE);
        pref.getString("hi", "");
    }
         // 값 저장하기
    private void savePreferences(){
        SharedPreferences pref = getSharedPreferences("pref", MODE_PRIVATE);
        SharedPreferences.Editor editor = pref.edit();
        editor.putString("hi", "인사잘하네");
        editor.commit();
    }
         // 값(Key Data) 삭제하기
    private void removePreferences(){
        SharedPreferences pref = getSharedPreferences("pref", MODE_PRIVATE);
        SharedPreferences.Editor editor = pref.edit();
        editor.remove("hi");
        editor.commit();
    }
         // 값(ALL Data) 삭제하기
    private void removeAllPreferences(){
        SharedPreferences pref = getSharedPreferences("pref", MODE_PRIVATE);
        SharedPreferences.Editor editor = pref.edit();
        editor.clear();
        editor.commit();
    }
}
 
 SharedPreferences pref = getSharedPreferences("pref", MODE_PRIVATE);

 

getSharedPreferences("pref", MODE_PRIVATE) 에서 "pref" 는 File 이름이라고 생각하시면 됩니다. 하나의 폴더에 여러개의 File이 존재 할 수 있듯이 하나의 어플리케이션에서도 여러개의 SharedPreferences(File) 가 존재 할 수 있습니다. 그러므로 "pref"는 SharedPreferences 이름이라고 보시면 됩니다.
값을 저장하고 불러올때 SharedPreferences 이름이 틀리지 않게 주의하시면 됩니다.

 


사용하실때는 SharedPreferences 는 (Key, Value) 형태로 사용하시면 됩니다. 불러오실때 getString(key, value)를 설정하지만 해당 key에 대한 값이 없을경우 입력한 Value가 Default 값으로 설정됩니다. 즉 위에 보시는것과 같이 key값이 없을경우 "" 공백을 리턴받게 됩니다.

 


또한 주의하실게 get 메서드를 제외한 Data 저장(put), 삭제(remove, clear) 등을 할 경우에는 commit()을 꼭 호출해 주어야 합니다.