You must use the @+
notation on the first occurrence of the ID within an XML file. The second and subsequent times you can -- and should -- drop off the +
sign. This will help catch typos.
For example, suppose that you have a RelativeLayout
. You have a TextView
in that RelativeLayout
whose android:id
is @+id/label
. Later on in the layout XML file, you want to refer to that TextView
from another one for positioning purposes (e.g., for android:layout_below
).
If you typed in android:layout_below="@+id/labbel"
(note the typo), at compile time, this will be considered OK. However, at runtime, things will not work, ranging from the widget being positioned incorrectly to an outright crash, depending on Android version.
If you typed in android:layout_below="@id/labbel"
(note the typo and the missing +
sign), then you would get a compile error.
UPDATE
Since I wasn't clear enough the first time, apparently, let's try again.
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="wrap_content">
<TextView android:id="@+id/label"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="URL:"
android:layout_alignBaseline="@+id/entry"
android:layout_alignParentLeft="true"/>
<EditText
android:id="@id/entry"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_toRightOf="@id/label"
android:layout_alignParentTop="true"/>
<Button
android:id="@+id/ok"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@id/entry"
android:layout_alignRight="@id/entry"
android:text="OK" />
<Button
android:id="@+id/cancel"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_toLeftOf="@id/ok"
android:layout_alignTop="@id/ok"
android:text="Cancel" />
</RelativeLayout>
Above, you will see a RelativeLayout
. You will notice that the first occurrences of each ID get the +
sign. The second and subsequent occurrences of each ID do not get the +
sign.
You could use the +
sign on all of them, but then if you make a typo, the compiler will not catch the problem.
The +
sign effectively states "allocate a new ID". Not having the +
sign states "use a previously-allocated ID, or fail at compile time if there is no such ID".