Read a String object from the Parcel . - Android android.os

Android examples for android.os:Parcel

Description

Read a String object from the Parcel .

Demo Code

/*/* w ww . ja v  a  2  s . c  om*/
 * Copyright (C) 2014 Neo Visionaries Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
//package com.java2s;

import android.os.Parcel;

public class Main {
    /**
     * Read a {@code String} object from the {@code Parcel}.
     *
     * <p>
     * First, this method reads a {@code boolean} value from the
     * {@code Parcel} using {@link #readBoolean(Parcel)} method.
     * When the read {@code boolean} value is {@code true}, this
     * method executes {@link Parcel#readString() in.readString()}
     * and returns the value. Otherwise, when the read {@code
     * boolean} value is {@code false}, this method returns
     * {@code null}.
     * </p>
     *
     * @param in
     *         {@code Parcel} to read from.
     *
     * @return
     *         {@code String} object or {@code null}.
     */
    public static String readStringWithPresenceFlag(Parcel in) {
        if (readBoolean(in)) {
            // Present.
            return in.readString();
        } else {
            // Not present.
            return null;
        }
    }

    /**
     * Read a {@code boolean} value from the {@code Parcel}.
     *
     * <p>
     * This method reads one {@code byte} and returns {@code true}
     * if the read value is not 0.
     * </p>
     *
     * @param in
     *         {@code Parcel} to read from.
     *
     * @return
     *         A {@code boolean} value read from the {@code Parcel}.
     */
    public static boolean readBoolean(Parcel in) {
        return (in.readByte() != 0);
    }
}

Related Tutorials