728x90
반응형

제일 상단에

 

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>

 

pageEncoding이 UTF-8로 제대로 되어있는지 확인 해보세요 ㅎ

 

페이지마자 인코딩이 달라서 그런거일수 있고요 ㅎ  WAS를 어떤걸 쓰시는지모르겠는데

 

톰켓 server.xml에

 

<Connector acceptCount="100" connectionTimeout="20000" disableUploadTimeout="true" enableLookups="false" maxHttpHeaderSize="8192" maxSpareThreads="75" maxThreads="150" minSpareThreads="25" port="8080" redirectPort="8443"/>

 

이부분 사이에  URIEncoding="UTF-8" 추가하시면 get방식으로 넘어가는 한글은 왠만해선 안깨질듯 하네요  ㅎ

 

ex)

<Connector URIEncoding="UTF-8" acceptCount="100" connectionTimeout="20000" disableUploadTimeout="true" enableLookups="false" maxHttpHeaderSize="8192" maxSpareThreads="75" maxThreads="150" minSpareThreads="25" port="8080" redirectPort="8443"/>

 

728x90
반응형

'Web Programming > java-jsp' 카테고리의 다른 글

부모창 컨트롤하기  (0) 2014.03.12
잘 되던 프로젝트가 갑자기 에러가!!  (0) 2014.02.24
PORT 접근 TEST[telnet ip port]  (0) 2014.02.17
java/jsp/json 간단예제  (0) 2014.02.17
<%! %>  (0) 2014.02.17
728x90
반응형
▶ 방화벽에서 막힌 경우

연결 중입니다. 잠시 기다리십시오...


▶ 프로세서가 안떠있는 경우

연결 중입니다. 잠시 기다리십시오...
원격 호스트가 시도된 connect 조작을 거부했습니다.

▶정상 접속인 경우

연결 중입니다. 잠시 기다리십시오...
호스트에에 연결됩니다.
이탈(Escape) 문자는 '^]'입니다.
[출처] telnet ip port (해당 포트로 접속이 가능한지 테스트)|작성자 그레고리

 

728x90
반응형
728x90
반응형

http://zero-gravity.tistory.com/197

 

이 두 라이브러리를 활용했다.

   javax-json-api-1.0.jar 파일의 경우 java 1.7 버전 이상에는 기본적으로 포함되어 있으므로 따로 다운로드 받지 않아도 된다.

   jettison 다운로드 경로 → http://jettison.codehaus.org/Download



↓ 데이터를 JSON 형태로 빌드하기.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
import java.io.IOException;
import java.util.HashMap;
import java.util.Map;
  
import javax.json.Json;
import javax.json.JsonArrayBuilder;
import javax.json.JsonBuilderFactory;
import javax.json.JsonObjectBuilder;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
  
import kr.co.techinmotion.web.IAction;
  
public class JsonBuildAction implements IAction {
  
    private boolean redirect = false;
      
    @Override
    public String process(HttpServletRequest request,
            HttpServletResponse response) throws ServletException, IOException {
          
        // key와 value로 구성되어있는 HashMap 생성.
        Map<STRING, String> m = new HashMap<STRING, String>();
          
        // Map 타입의 m을 BuilderFactory에 넣어준다. (JsonBuilderFactory는 Json을 만들기 위한 뼈대라고 보면 됨)
        JsonBuilderFactory factory = Json.createBuilderFactory(m);
          
        // createObjectBuilder는 하나씩 넣을 때, createArrayBuilder는 배열로 넣을 때.
        JsonObjectBuilder ob_1 = factory.createObjectBuilder();
        JsonObjectBuilder ob_2 = factory.createObjectBuilder();
        JsonObjectBuilder ob_3 = factory.createObjectBuilder();
        JsonArrayBuilder ab = factory.createArrayBuilder();
          
        // 첫번째 JsonObjectBuilder에 이름과 나이를 추가.
        ob_1.add("이름", "홍길동");
        ob_1.add("나이", "모름");
          
        // 두번째 JsonObjectBuilder에 홍길동의 위치(위도와 경로)를 추가.
        ob_2.add("위도", "36.3713874817");
        ob_2.add("경도", "127.645332336");
          
        // 세번째 JsonObjectBuilder에 홍길동의 위치(위도와 경로)를 추가.
        ob_3.add("위도", "50.153273512");
        ob_3.add("경도", "110.99976542");
          
        // 두번째와 세번째 JsonObjectBuilder를 ArrayBuilder에 넣어준다.
        ab.add(ob_2);
        ab.add(ob_3);
          
        // 첫번째 JsonObjectBuilder에 ArrayBuilder를 추가.
        ob_1.add("위치", ab);
          
        // 최종적으로 ob_1 JsonObjectBuilder를 build.
        String jsonStr = ob_1.build().toString();
          
        request.setAttribute("jsonStr", jsonStr);
          
        return "/WEB-INF/jsonTest.jsp";
    }
  
    @Override
    public boolean isRedirect() {
        return redirect;
    }
  
}



↓ 빌드한 JSON을 텍스트로 JSP에 뿌리기.

1
2
3
4
5
<FORM method=post action=jsonDismantle.ok>
    <TEXTAREA rows=5 cols=100 name=jsonText>        ${requestScope.jsonStr }
    </TEXTAREA><BR>
    <INPUT value=전송 type=submit>
</FORM>




그럼 위와 같이 나온다.




긁어서 http://jsonlint.com 에서 확인해보면 정확하게 만들어졌음을 알 수 있다.


전송을 클릭해서 다시 이 JSON 형태의 텍스트를 분해해보자.



↓ JSON 형태의 텍스트를 받아서 분해.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
import java.io.IOException;
import java.util.ArrayList;
  
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
  
import org.codehaus.jettison.json.JSONArray;
import org.codehaus.jettison.json.JSONException;
import org.codehaus.jettison.json.JSONObject;
  
import kr.co.techinmotion.web.IAction;
  
public class JsonDismantleAction implements IAction {
  
    private boolean redirect = false;
      
    @Override
    public String process(HttpServletRequest request,
            HttpServletResponse response) throws ServletException, IOException {
          
        String jsonText = request.getParameter("jsonText");
          
        String name = null;
        String age = null;
          
        ArrayList<STRING> locationArray = new ArrayList<STRING>();
          
          
        try {
            JSONObject jo = new JSONObject(jsonText);
            name = jo.getString("이름");
            age = jo.getString("나이");
              
            JSONArray array = jo.getJSONArray("위치");
            for(int i=0; i < array.length(); i++){
                JSONObject jsonObject = array.getJSONObject(i);
                String lat = jsonObject.getString("위도");
                String lon = jsonObject.getString("경도");
                locationArray.add(i, "위도 : " + lat + ", 경도 : " + lon);
            }
              
        } catch (JSONException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
          
        request.setAttribute("name", name);
        request.setAttribute("age", age);
        request.setAttribute("locationArray", locationArray);
          
        return "/WEB-INF/jsonResult.jsp";
    }
  
    @Override
    public boolean isRedirect() {
        return redirect;
    }
  
}



↓ 분해한 데이터를 JSP에 출력하기

1
2
3
4
5
6
7
8
이름은? : ${name } <BR>
나이는? : ${age } <BR><BR>
  
<C:IF test="${!empty locationArray}">
    <C:FOREACH var="lo" items="${locationArray}">
        위치는? ---> ${lo} <BR>
    </C:FOREACH>
</C:IF>





출력하면 위와 같이 나온다.



   굉장히 간단하다.


   이런 게 있는줄도 모르고 무식하게 일일히 String으로 붙여가면서 하는 사람도 있을 듯. 예전의 나처럼. ㅡㅡ;;;


   이해한다.. 존재 자체도 모르니 필사적으로 찾아보지 않으면 그렇게 되는 거다...


   이제 이런 걸 써먹자.

 

728x90
반응형

'Web Programming > java-jsp' 카테고리의 다른 글

jsp 한글깨짐!!!!!!!!!!!!!!!!  (0) 2014.02.17
PORT 접근 TEST[telnet ip port]  (0) 2014.02.17
<%! %>  (0) 2014.02.17
[Java] 객체 사용후 null 할당! 해야하나 말아야 하나?  (0) 2014.02.17
오라클 nvl, decode  (0) 2014.02.03
728x90
반응형
<%
이것으로 감싸여져 있는 부분은 JSP 코드중에 JAVA 구현부분 입니다.
이부분은 서버에서 실행이됩니다.
%>

<script>
이부분으로 감싸여져 있는 부분은 스크립트 부분입니다.
사용자에게 html 로 전송된 이후에 실행되는 부분으로 html 의 일부분입니다.
</script>

두개는 좀 다른 의미로 자바는 프로그램적인 부분이고 스크립트는 마크업 랭기쥐의 일부분으로

사용자 환경에서 실행되는 명령어에 해당합니다.

자바 부분도 함수 정의가 가능합니다.

<%!

%>

느낌표가 앞에 붙는다는것이 다르며 이또한 서버에서만 실행되어 집니다.

<scipt></scipt> 를 <%%> 로 바꾸시면 오류가 날수밖에 없습니다.

<%%> 속에 들어가는 구분은 java 문법의 구문을 다르며 <scipt></scipt>속에 들어가는 구문은

javascript 문법구문을 따르게 되어있습니다.

두개의 명령어와 문법 표현 방식은 전혀 다른것이라고 보시면 되구요.

실행되는 시점도 전혀 다릅니다.

사용자는 <%%> 이부분을 제외한 부분만을 보여지게 되며 <%%> 부분으로 둘러쌓여있는 부분은

서버에서 동적으로 반복 또는 문구를 출력하여 html 문서를 동적으로 완성하여 사용자에게 전송 하는것 입니다.

 

728x90
반응형
728x90
반응형

[Java] 객체 사용후 null 할당! 해야하나 말아야 하나?

lemonfish.egloos.com/5380639

오늘도 포스팅 대용으로 네이뇬~ 지식 KIN 에 달았던 답변을 옮겨 본다. 지금껏 달았던 답변중 가장 재밌는 질문이 아니었나 생각된다.

질문은 이런 내용 이었다.

현재 메모리 누수 현상이 있어
jdbc connection 관련해서 확인하고 있는데요

보통 PreparedStatement, ResultSet 사용 후 finally 절에서 close 하자나요
근데 Vector 라든지 StringBuffer 도 사용 후 null 처리를 하고 종료를 해야하는지 잘 모르겠네요

소스에서 null 된것도 있고 안된것도 있고;; 헷갈리네요
구글링 해도 잘 안나와 있고 ㅠㅜ
...

이 질문에 대한 내 생각은 이렇다...

=================================================================

*제 답변은 일반적으로 많이 사용하는 썬의 (지금은 오라클이지만.. ㅜ_ㅜ) JVM 구현을 기준으로 합니다.

의견이 상당히 많이 달려있군요. 

메모리와 관련하여

1. 객체를 사용하고 나서 null 할당하는건 코드만 더럽히는 짓이다 vs 꼭꼭 null 처리해주는 좋은습관!
2. null 을 할당하는것은 별 의미없다 vs 이건 정말 중요하다
3. null 을 할당한다면 언제 할당해야 하느냐?



이런것들은 자바를 사용하는 개발자들 사이에서 오랫동안 논란이 되어왔고 아직도 논란이 되고 있는 부분이지요. 사실상 이 논란은 자바라는 언어에서 프로그래머가 직접 메모리를 할당/관리 하지 않기때문에 발생하는 것입니다. 하지만 GC 의 원리를 이해하게되면 null 할당이 편집증걸린 프로그래머나 할만한 일은 아니라는것을 알게됩니다. 그리고, 자바라는 언어가 이런 부분들을 해소하기 위해 어떤 노력을 했는지도 알수 있지요. (뒤에 null 할당이 아닌 다른 방법으로 동일한 효과를 얻는 예제를 소개 하겠습니다.) 

위의 3가지 논란에 대해 정리하기에 앞서 한가지 모두가 인정할만한 부분을 짚고 넘어가겠습니다. 

작은 프로그램(혹은 메서드)에서는 null 할당은 큰 의미가 없습니다. 여기서 작은 프로그램이란 
  • 프로그램(혹은 메서드) 자체의 동작시간이 짧고
  • 객체의 생성이 빈번하지 않으며
  • 적은 메모리를 사용하는 
  • 메모리 누수가 문제되지 않는
  • 실행시 지정한(혹은 기본값) 힙사이즈를 채 반도 사용하지 않는
프로그램(메서드)으로 정의해 보겠습니다. (좀더 구체적으로 정의할 방법도 있겠습니다만 당장 떠오르는게 저것밖에 없네요. ^-^;;) 사실 공부하려고 짜보는 프로그램이 아닌 어느정도 규모있는 프로그램이라면 대부분 위의 네가지에 정반대되는 경우일 겁니다.  제가 계속 프로그램이라는 단어에 괄호치고 메서드라고 넣는 이유는 프로그램 전체가 위의 항목에 해당 될수도 있지만 어느 클래스의 특정 메서드가 위의 항목에 해당되는 경우도 있기 때문입니다. 이를 테면 작은 프로그램인데 몇개의 클래스에 정의된 특정 메서드들이 프로그램의 실행시간의 많은 부분을 차지한다던가 그 메서드에서만 메모리를 많이 사용한다던가 라는 상황도 있기 때문입니다. 

(프로그램(메서드)의 규모는 개발자마다 체감되는게 다르기 때문에 작다 크다 정의내리면 논란이 되는 경우가 많은데 일단 얘기를 이어나가야 하니 넘어갑시다.)

맨위에서 언급한 논란의 각각에 작은 프로그램(메서드)의 정의를 반대로 적용해 보시면 도움이 될겁니다. 정의를 반대로 적용봤을때 해당한다면 고민하지 마시고 아래의 방법을 추천드립니다.

지금 작성하고 있는 코드가 큰 프로그램(메서드)의 일부라면 항상 가능한한 모든 객체의 사용후 null 을 할당해 주어야 하며, 이것은 정말 중요한 부분입니다.

왜 위와 같이 해야하는지 몇가지 예제을 통해 살펴보도록 하겠습니다. 직접 붙여넣고 실행 해보시기 바랍니다. (실행시 VM 옵션으로 -verbose:gc 를 추가하셔서 실제 GC 가 일어나는 것을 확인해 보세요.)

첫번째 예제 : null 을 안주면 어떻게 되나?

public class GCTest {
private final static int ALLOC_SIZE = (int) (Runtime.getRuntime().maxMemory() * 0.60);

public void allocate() {

System.out.println("Before first allocation");
byte[] b = new byte[ALLOC_SIZE];
System.out.println("After first allocation");

System.out.println("Before second allocation");
byte[] b2 = new byte[ALLOC_SIZE];
System.out.println("After second allocation");

}

public static void main(String[] args) {
new GCTest().allocate();
}
}

먼저 예제를 설명 드리자면 가용한 메모리의 60% 를 allocate 라는 메서드의 첫번째 지역 변수인 b 에서 할당을 합니다. 그리고 이후에는 전혀 사용되지 않고 있지요. 그리고 나서 다시 두번째 지역변수인 b2 에서 또 60% 를 할당을 합니다. 

위의 예제의 결과는 아래 와 같습니다.

Before first allocation
After first allocation
Before second allocation
[GC 555205K->555136K(712576K), 0.0017096 secs]
[GC 555136K->555104K(712576K), 0.0045040 secs]
[Full GC 555104K->555088K(660160K), 0.0052565 secs]
[GC 555088K->555088K(712576K), 0.0071493 secs]
[Full GC 555088K->555066K(665280K), 0.0062704 secs]
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
at GCTest.allocate(GCTest.java:12)
at GCTest.main(GCTest.java:18)

첫번째 할당은 정상적으로 이뤄졌지만 두번째 할당을 진행하려고 보니 메모리가 부족한 상황이라 마이너 GC 가 발생하고 연달아 Full GC 까지 이뤄 졌습니다. 하지만 메모리는 여전히 부족합니다. 왜냐면 메서드가 반환되기 이전에는 b 의 참조가 존재하므로 (설사 사용되지 않는다 하더라도) GC 대상에서 제외되었기 때문입니다. 누가봐도 당연히 OOM (Out of memory) 가 나는 상황입니다. 또한 누가봐도 b2 를 할당하는 시점에 GC 가 일어 난다고 예상이 됩니다. (메모리가 부족한 상황에서 GC 는 반드시 일어납니다.) 

이 예제는 조건을 극단적으로 단순화 해놨을 뿐이지 규모가 큰 프로그램(메서드) 에서는 언제든 발생할 수 있는 상황입니다. 예를 들어 여러 스레드가 동작하며 각각 어떤 메서드를 실행을 하는데 그 메서드가 이런 구조라면

메서드 호출 -> 객체 잔뜩 생성 -> 객체 마구 사용(이후에는 사용안함) -> 블럭되는 I/O 처리 -> 반환

메서드가 종료되기 전까지 참조를 물고있는 사용되지 않는 지역변수들이 점점 쌓여 갈겁니다. 결국 메모리가 부족해 GC 가 수행되더라도 GC 의 대상이 되어야할 객체들은 참조를 물고 있으니 OOM(버틸수가없다) 으로 직행하는 거지요.

두번째 예제 : null 을 주면 어떻게 되나?

public class GCTest2 {
private final static int ALLOC_SIZE = (int) (Runtime.getRuntime().maxMemory() * 0.60);

public void allocate() {

System.out.println("Before first allocation");
byte[] b = new byte[ALLOC_SIZE];
System.out.println("After first allocation");
b = null;
System.out.println("After assign null to b");
System.out.println("Before second allocation");
byte[] b2 = new byte[ALLOC_SIZE];
System.out.println("After second allocation");
}
public static void main(String[] args) {
new GCTest2().allocate();
}
}

첫번째 예제와 상황은 동일합니다. 하지만 b 를 다쓰고 나서 null 할당 해주었지요.
결과는 이렇습니다.

Before first allocation
After first allocation
After assign null to b
Before second allocation
[GC 555205K->555168K(712576K), 0.0019313 secs]
[GC 555168K->555104K(712576K), 0.0027482 secs]
[Full GC 555104K->208K(105344K), 0.0509913 secs]
After second allocation

예상하셨다시피 OOM 은 일어나지 않았습니다. 앞서 언급했던 

메서드 호출 -> 객체 잔뜩 생성 -> 객체 마구 사용(이후에는 사용안함) -> 블럭되는 I/O 처리 -> 반환

이런 구조의 메서드를 

메서드 호출 -> 객체 잔뜩 생성 -> 객체 마구 사용(이후에는 사용안함) -> 마구사용한 객체 가차없이 null 할당 -> 블럭되는 I/O 처리 -> 반환

이렇식으로 수정한 것과 동일합니다. OOM 으로 직행하려다가 현명한 개발자 덕분에 GC 가 보람있는 일을 했네요. 일례로 많은 사용자를 대상으로 하는 웹어플리케이션에는 아주 딱 들어맞는 상황입니다. 특히. 웹이라는 특성상 서비스의 유형에 따라 피크타임이 존재하기 때문에 더더욱 적합합니다. (개발자의 상황에 적합하지 못한 코드 덕분에 심심하면 죽어나간 서버가 한둘이 아닙니다.)

조건을 단순화한 예제이지만 대부분의 큰 프로그램의 어딘가에서 null 할당을 해줘야 하나 말아야 하나를 고민할때 생각해 볼만한 예제라고 생각이되는군요.

적다보니 내용이 너무 길어 지는 감이 있어 앞에서 얘기한 null 할당 이외의 방법을 소개하고 끝내도록 하겠습니다. 

자바가 처음 나온후 컴퓨터 분야에서는 꽤 오랜 시간이 흘렀습니다.  VM 이 알아서 메모리를 관리해 준다는 장점은 사용하다보니 다른 문제들을 야기하게 되었습니다. 바로 "우린 좀더 GC 와 얘기하고싶다" 라는 건데요.

null 할당은 GC 가 일어나기만 하면 바로 회수해 가버리고 이후에 해당 객체를 더이상 사용할 수 없지만.

1. GC 를 한번 해보고, 메모리가 충분하다면 계속 참조하고 싶다
2. GC 가 일어나기 전까지만 계속 참조하고 싶다.
3. finalize 이후에 뭔가 더 처리 하고 싶다.

라는 요구사항들이 여기저기서 터져나오기 시작한거죠. 결국 1.2 버전에서 새로운 클래스들이 소개되기 에 이르렀는데 그게 바로 

java.lang.ref 

패키지 입니다. 현재 많은 오픈소스 캐싱 라이브러리 들이 이 패키지를 잘 활용한 예제이지요.  여기에는 딱 5개의 클래스가 존재 합니다.

Reference, PhantomReference, SoftReference, WeakReference, ReferenceQueue

입니다. 여기서 주역들은 

1. GC 를 한번 해보고, 메모리가 충분하다면 계속 참조하고 싶다 (SoftReference)
2. GC 가 일어나기 전까지만 계속 참조하고 싶다. (WeakReference)
3. finalize 이후에 뭔가 더 처리 하고 싶다. (PhantomReference)

이 3가지 클래스 입니다. 저는 WeakReference 와 SoftReference 를 소개 하겠습니다.

WeakReference 예제

import java.lang.ref.WeakReference;

public class GCTest3 {
private final static int ALLOC_SIZE = (int) (Runtime.getRuntime().maxMemory() * 0.60);
public void allocate() {
System.out.println("Before first allocation");
WeakReference<byte[]> b = new WeakReference<byte[]>(new byte[ALLOC_SIZE]);
System.out.println("After first allocation");

System.out.println("b is alive ? " + b.get());
System.out.println("Before second allocation");
byte[] b2 = new byte[ALLOC_SIZE];
System.out.println("After second allocation");
System.out.println("b is alive ? " + b.get());
}
public static void main(String[] args) {
new GCTest3().allocate();
}
}

수행 결과는 

Before first allocation
After first allocation
b is alive ? [B@64c3c749
Before second allocation
[GC 555205K->555168K(712576K), 0.0016671 secs]
[GC 555168K->555104K(712576K), 0.0015086 secs]
[Full GC 555104K->208K(105344K), 0.0562847 secs]
After second allocation
b is alive ? null

GC 한방에 날아가버렸네요.


SoftReference 예제


import java.lang.ref.SoftReference;

public class GCTest3 {
private final static int ALLOC_SIZE = (int) (Runtime.getRuntime().maxMemory() * 0.60);
public void allocate() {
System.out.println("Before first allocation");
SoftReference<byte[]> b = new SoftReference<byte[]>(new byte[ALLOC_SIZE]);
System.out.println("After first allocation");

System.out.println("b is alive ? " + b.get());
System.out.println("Before second allocation");
byte[] b2 = new byte[ALLOC_SIZE];
System.out.println("After second allocation");
System.out.println("b is alive ? " + b.get());
}
public static void main(String[] args) {
new GCTest3().allocate();
}
}


WeakReference 의 예제에서 SoftReference 로 클래스만 바뀌었습니다.

결과를 볼까요?

Before first allocation
After first allocation
b is alive ? [B@7150bd4d
Before second allocation
[GC 555205K->555136K(712576K), 0.0016918 secs]
[GC 555136K->555104K(712576K), 0.0014965 secs]
[Full GC 555104K->555088K(660160K), 0.0045636 secs]
[GC 555088K->555088K(712576K), 0.0068316 secs]
[Full GC 555088K->186K(110208K), 0.0575150 secs]
After second allocation
b is alive ? null

한번 해보고 버틸수가 없다! 이러니까. 결국 이녀석도 날아가 버렸네요.


오늘 제가 여지껏 지식인에서 했던 답변중 제일 긴 답변인것 같습니다.

꼭 도움이 됐길 바랍니다. 즐겁게 프로그래밍 하시구요~ 그럼 이만!

덧글

  • regen 2010/10/30 04:46
    잘 보았습니다^^
    • killy 2010/10/30 23:26
        네 방문해 주셔서 감사합니다~
    • 여름눈 2010/10/30 13:49
      정말 좋은 정보인데요~~C#이 자바와 문법 및 구조가 거의 동일하기 때문에 저에게도 많은 도움이
      되는 내용이었습니다.

      하다보면 그냥 null 한줄 넣기가 귀찮아서 그냥 종종 넘어간 경우가 많았거든요~~^^;
      • killy 2010/10/30 23:28
          도움이 되셨다니 키보드를 두드린 보람이 있네요~!
      • 몽몽이 2010/10/30 22:10
        호오. 좋은 내용입니다.
        순순히 java.lang.ref를 이용한다면 메모리 부족 사태는 일어나지 않을 것입니다;;;
        • killy 2010/10/30 23:32
            문명을 아시는 분이시군욧~! 저는 늘 Bloodthirsty 로 불린 답니다. ㅋ
        • 샤를린 2011/12/29 16:33
          재밌고 유익한 글 잘보았습니다~ 감사합니다^^
          • killy 2012/01/06 22:22
              넵 방문해 주셔서 감사합니다.
          • 나그네 2012/10/04 10:18
            메모리 누수? 해결법 찾다가 떠오르는게 null 밖에 없어서 검색해보다 들왔는데
            null은 필요악이란거네요.. 규모가 클때는 유용하지만 작을때는.. 소스가 다소 지저분? 해질 수 있다는..
            그리고 null말고 저런 고급스런?? 방법도 있었네요..
          728x90
          반응형

          'Web Programming > java-jsp' 카테고리의 다른 글

          java/jsp/json 간단예제  (0) 2014.02.17
          <%! %>  (0) 2014.02.17
          오라클 nvl, decode  (0) 2014.02.03
          특정 ip 포트가 열려있는지 확인하는 법  (0) 2014.01.13
          enterkey event 처리  (0) 2013.12.12

          + Recent posts