Поведение оператора return в catch и наконец - PullRequest
10 голосов
/ 28 февраля 2012
public class J {

     public Integer method(Integer x) 
        {
            Integer val = x;
            try 
            {

                    return val;
            } 
            finally 
            {
                     val = x + x;
            }
        }
        public static void main(String[] args) 
        {
            J littleFuzzy = new J();
            System.out.println(littleFuzzy.method(new Integer(10)));
        }

}

Будет возвращено "10".

Теперь я просто заменяю тип возвращаемого значения Integer на StringBuilder, и выход был изменен.

public class I {

     public StringBuilder method(StringBuilder x) 
        {
            StringBuilder val = x;
            try 
            {

                    return val;
            } 
            finally 
            {
                     val = x.append("aaa");
            }
        }
        public static void main(String[] args) 
        {
            I littleFuzzy = new I();
            System.out.println(littleFuzzy.method(new StringBuilder("abc")));
        }


}

OutPut равен "abcaaa"

Так, кто-нибудь может объяснить мне подробно.?в чем различия .?

Ответы [ 3 ]

4 голосов
/ 28 февраля 2012

Просто потому, что целое число в immutable, так что после метода возвращается, даже если значение изменяется в методе, оно не отражается, а отражается в StringBuilder Объект

EDIT:

public class J {
    public String method(String x) {
        String val = x;
        try {
            return val;
        } finally {
            val = x + x;
        }
    }

    public static void main(String[] args) {
        J littleFuzzy = new J();
        System.out.println(littleFuzzy.method("abc"));
    }
}
0 голосов
/ 28 февраля 2012

Когда объект передается, копия его ссылки передается, и вы можете изменить содержимое, если оно изменчиво.

0 голосов
/ 28 февраля 2012

Основными операциями в StringBuilder являются методы добавления и вставки, которые перегружены, чтобы принимать данные любого типа.Каждый из них эффективно преобразует данный элемент данных в строку, а затем добавляет или вставляет символы этой строки в построитель строк.Метод append всегда добавляет эти символы в конце компоновщика;метод вставки добавляет символы в указанной точке.

Например, если z ссылается на объект строителя строк, текущее содержимое которого - "start", то вызов метода z.append ("le") вызоветв строителе строк содержится «startle», тогда как z.insert (4, «le») изменит строитель строк на «starlet».

В общем случае, если sb ссылается на экземпляр StringBuilder,тогда sb.append (x) имеет тот же эффект, что и sb.insert (sb.length (), x).У каждого строителя строки есть способность.Пока длина символьной последовательности, содержащейся в построителе строк, не превышает емкости, нет необходимости выделять новый внутренний буфер.Если внутренний буфер переполняется, он автоматически увеличивается.

Экземпляры StringBuilder небезопасны для использования несколькими потоками.Если такая синхронизация необходима, рекомендуется использовать StringBuffer.

В вышеприведенном методе блок finally всегда вызывается.

...