예시



HTML


<div class="box">

  <img src="https://t1.daumcdn.net/cfile/tistory/99FB9E335A0696E312">

</div>


CSS


.box{

   height:200px;

   width: 200px;

   overflow: hidden;   

    }

.box img{

   height:100%;

   width: 100%;

   object-fit:cover;     


/* 마우스가 이미지를 벗어 났을 때도 자연스럽게 크기가 줄어들기 위함 */

   transform:scale(1.0);        

   transition: transform .5s; 

}

.box img:hover{            /* 마우스 호버시 */

   transform:scale(1.5);            /* 이미지 확대 */

   transition: transform .5s; /*  시간 설정  */

}


/*

*/






CSS에 추가

.ui-autocomplete {

  z-index:2147483647;

}


출처:https://stackoverflow.com/questions/16133654/autocomplete-issue-into-bootstrap-modal

<input type='file' accept='image/*' onchange='openFile(event)'><br>

<img id='output'>

<script>

  var openFile = function(event) {

    var input = event.target;


    var reader = new FileReader();

    reader.onload = function(){

      var dataURL = reader.result;

      var output = document.getElementById('output');

      output.src = dataURL;

    };

    reader.readAsDataURL(input.files[0]);

  };

</script>



실행 예시





출처:http://www.javascripture.com/FileReader

html,body,.container {

    height:100%;

}

.container {

    display:table;

    width: 100%;

    margin-top: -50px;

    padding: 50px 0 0 0; /*set left/right padding according to needs*/

    box-sizing: border-box;

}


.row {

    height: 100%;

    display: table-row;

}


.row .no-float {

  display: table-cell;

  float: none;

}


ProxyAOP(Aspect Oriented Programming) : 관점 지향 프로그래밍


기능을 핵심 비지니스 로직과 공통 모듈로 구분하고, 핵심 로직에 영향을 미치지 않고 사이사이에 공통 모듈을 효과적으로 잘 끼워넣도록 하는 개발 방법이다. 공통모듈(트랜잭션/로그/보안/인증 처리 등)을 만든 후에 코드 밖에서 이 모듈을 비지니스 로직에 삽입하는 것이 바로 AOP 적인 개발이다. 코드 밖에서 설정된다는 것이 핵심이다.


core concern 핵심 관심

프로그램을 작성하려는 핵심 가치와 목적이 드러난 관심 영역으로 보통 핵심 비지니스 기능에 해당한다.

cross cutting concern 횡단관심 

핵심 관심에 영향을 주는 프로그램의 영역으로, 로깅과 트랜잭션, 인증처리와 같은 시스템 공통 처리 영역이 해당된다.


join-point

횡단 관심 모듈의 기능이 삽입되어 동작 할 수 있는 실행 가능한 특정 위치


point-cut

어떤 클래스의 어느 조인포인트를 사용 할 것인지를 결정하는 선택기능

advice

join-point에 삽입되어저 동작 할 수있는 코드


aspect (advisor) = point-cut + advice


weaving (crossCutting)

포인트컷에 의해서 결정된 조인포인트에 지정된 어드바이스를 삽입하는 과정


Target Object

대상 객체는 충고(Advice)를 받는 객체이다. Spring AOP는 런타임 프록시를 사용하므로 대상 객체는 항상 프록시 객체가 된다.


Proxy

AOP 프록시(Proxy)는 대상 객체(Target Object)에 Advice가 적용된 후 생성되는 객체이다.


dynamic proxy 

A proxy that creates the actual proxy class at runtime.












'기타' 카테고리의 다른 글

양념  (0) 2017.07.25


'기타' 카테고리의 다른 글

AOP  (0) 2017.07.26




<원인>

eclipse.ini 에서 vm을 jdk 경로로 설정하였으나, 인식하지 못함.

vm을 설정할 때 jdk의 운영체제 bit 와 eclipse의 운영체제 bit가 일치해야함.

32bit eclipse를 사용할 경우 vm 경로를 32bit jre 경로로 설정해야 함.

64bit eclipse를 사용할 경우 vm 경로를 64bit jre 경로로 설정해야 함.


<해결방안>


eclipse.ini 에서 vm 경로를 jre 경로로 설정.


<eclipse.ini>


-startup

plugins/org.eclipse.equinox.launcher_1.3.0.v20120522-1813.jar

–launcher.library

plugins/org.eclipse.equinox.launcher.win32.win32.x86_1.1.200.v20120522-1813

-product

org.eclipse.epp.package.jee.product

–launcher.defaultAction

openFile

–launcher.XXMaxPermSize

256M

-showsplash

org.eclipse.platform

–launcher.XXMaxPermSize

256m

–launcher.defaultAction

openFile

-vm

C:/Program Files (x86)/Java/jre7/bin/javaw.exe

-vmargs

-Dosgi.requiredJavaVersion=1.5

-Dhelp.lucene.tokenizer=standard

-Xms512m

-Xmx512m

-Dfile.encoding=UTF-8


출처:http://blog.daum.net/chemusic/51


 Web 서버

- HTTP 프로토콜을 기반으로 하여, Web 클라이언트(브라우저) 부터의 요청을 서비스 하는 기능을 담당하는

프로그램(일반적으로 Apache 많이 사용함)

- Web 서버의 역할은 html, 이미지(jpg, gif.. ), xml 등에 대한 처리를 담당(CGI 프로그램 요청도 처리)

 Web Appication 서버

여러 Web 클라이언트(브라우저) 요구를 Web 서버 혼자 감당하기에는 힘들기 때문에구조적으로 Web

서버의 기능을 분리하기 위해 만들어진 것으로 Web Applicatioin Server(WAS)라고 한다.(일반적으로

Tomcat, Weblogic, WebShpare, Jeus, JBoss 등이 이용된다.)

 Web 서버와 Web Applicatiion 서버의 차이점

- Web 서버와 Web Application 서버는 위의 설명처럼 사용의 목적이 다르다. Web 서버는 html, 이미지들의 요청을 처리하는데 빠르고 , Web Application 서버는 Servlet이나, JSP 비지니스 로직을 수행하는데 적합하다.(웹컨테이너란 이러한 ServletJSP 수행하는 역할을 하는 서버를 말한다.) 그렇다고 Web Application Server html, 이미지들의 요청을 처리하지 못한다는 얘기는 아니다다만 처리 속도가 Web 서버에 비해 느리다는  뿐이다이렇게 서로 다른 강점을 합해서 사용하기 위해 Web 서버와 Web Application 서버를 연동하여 서비스를 하는 것이 대부분이다.

 [참조] JSP 기초 http://cafe.naver.com/tonkjsp/6

 Tomcat

- Tomcat JSP 환경을 포함하고 있는 Servlet 컨테이너

- Servlet 컨테이너는 사용자 입장에서 Servlet 유지하고 호출하여 실행하는 

- Tomcat 크게 3가지로 컨테이너로 구분한다.

 Stand-alone servlet containers(Tomcat 기본 모드)

내장된 웹서버의 기능을 사용하는 

기능면에서 JavaWebServer 부분인 Serlvet 컨테이너와 Java 근간  서버를 사용

 In-process servlet containers

- Servlet 컨테이너는 웹서버 플러그인과 Java 컨테이너 구현

웹서버 플러그인은 웹서버의 주소 공간 내에 JVM 열고  안에서 JAVA 컨테이너가 실행되도록 한다.

다중 스레드의 단일 프로세스 서버에 적당하고 퍼포먼스도 좋지만 확장성에 한계가 있음

 Out-of-process servlet containers

웹서버 플러그인과 웹서버의 외부 JVM에서 실행하는 JAVA 컨테이너 구현

웹서버 플러그인과 JAVA 컨테이너 JVM 몇몇 IPC(보통은 TCP/IP 소켓) 사용해서 통신

- Out-of-process 엔진의 반응 시간은 in-process 만큼 좋지 않지만 out-of-process 엔진은 확장성과 안전성 면은 In-process보다 좋다.

 톰캣 디렉토리 구조

- tomcat 6.0 에서는  그림 처럼 되어 있지 않고 common, server 빠진 상태로 되어 있다.

- common, server 빠진 상태로 정리하면

디렉토리명

기능 설명

bin

여기에는 톰캣 서버의 동작을 제어할  있는 스크립트  실행 파일들이 포함되어 있습니다.

conf

톰캣의 기본적인 설정 파일들이 포함되어 있습니다.

lib

아파치와 같은 다른  서버와 톰캣을 연결해주는 바이너리 모듈들이 포함되어 있습니다.

webapps

톰캣이 제공하는  애플리케이션의 기본 위치입니다.

logs

서버의 로그 파일이 저장되는 디렉토리입니다.

Work

JSP 컨테이너와 다른 파일들이 생성하는 임시 디렉토리입니다.

temp

임시 저장 폴더

위의 그림과 같이 항상 같은 구조를 표준 처럼 유지 되어야 한다. 




요구되는
 형태로  어플리케이션 보관소 생성을 용이하게 하기 위해서 어플리케이션의 "실행파일들( 어플리케이션을 실행할  톰캣이 사용하는 파일들) WAR 형식에서 요구하는 것과 같은 구성으로 정리하는게 편합니다이렇게 하려면 어플리케이션의 "문서 루트 document root" 디렉토리에 다음 내용으로 구성합니다

  • *.html, *.jsp, 등. - 웹 어플리케이션에서 클라이언트 브라우저로 전송이 되는 HTML 과 JSP 페이지와 다른 파일들 (예를 들면 자바스크립트, 스타일시트, 이미지 같은). 대규모 어플리케이션에서 이 파일들을 서브디렉토리 체계로 나누어 놓을 수 있습니다. 그러나 규모가 작은 어플리케이션이라면 보통은 하나의 디렉토리에서 전체를 관리하는 것이 보다 단순하고 쉽습니다.
  • /WEB-INF/web.xml - 웹 어플리케이션의 웹 어플리케이션 배치 설명자 Web Application Deployment Descriptor. 서블릿과 웹어플리케이션을 구성하는 다른 컴포넌트들을 설명하고, 각종 초기화 파라메터들과 서버 기능을 활용하기 위한 컨테이너가 관리하는 보안 제한 구역을 지정하는 XML 파일입니다. 다음 섹션에서 좀 더 자세히 알아보도록 하겠습니다.
  • /WEB-INF/classes/ - 이 디렉토리에는 웹 어플리케이션에서 사용하는 모든 자바 파일(그리고, 관련 자원)이 들어있습니다. 서블릿과 비서블릿 클래스 파일들이며 jar 형태로 묶여있지 않은 것입니다. 패키지가 선언된 클래스라면 /WEB-INF/classes/ 를 기준으로 패키지의 디렉토리를 만들어 구성하면 됩니다. 예를 들어, 클래스명이 com.mycompany.mypackage.MyServlet 라면 파일의 저장경로는 /WEB-INF/classes/com/mycompany/mypackage/MyServlet.class 이 됩니다.
  • /WEB-INF/lib/ - 이 디렉토리에는 웹어플리케이션에서 사용하는 자바 클래스파일을 포함하는 JAR 파일들이 위치합니다. 외부 클래스 라이브러리나 JDBC 드라이버 같은 것들입니다.

톰캣(또는 다른 2.2/2.3 호환 서버)에 어플리케이션을 설치할 때, WEB-INF/classes/ 에 있는 클래스들과 WEB-INF/lib/ 디렉토리에 있는 JAR파일에 있는 모든 클래스들은 같은 웹 어플리케이션에서 사용하는 모든 클래스가 접근가능하게 되어있습니다. 따라서, 만일 이 디렉토리 안에 사용하는 모든 라이브러리 클래스들을 몰아 넣으면 (외부 라이브러리를 사용하는 경우 재배포 권한에 관한 라이센스를 확인하길 바랍니다.), 웹 어플리케이션의 설치가 간단히 끝날 수 있습니다 -- 시스템 클래스패스에 대한 조정(또는 서버에 있는 전체 라이브러리의 설치)도 필요 없습니다.

 톰캣 환경설정(server.xml)

- tomcat에서 주요한 환경설정 파일  하나 입니다.

컴포넌트에 대한 초기 설정 제공

- tomcat 대한 구조를 지정

- server.xml 구조  계층적 엘리먼트

상위의 속성은 자동적으로 하위의 요소에 계승된다예를 들어 <Host> 구성요소 <Logger>  속성은 아무것도 지정하지 않은 경우 <Engine> 구성 요소 <Logger> 설정이 사용된다변경이 필요한 경우에는 <Host> 구성요소 <Logger> 별도의 설정을 함으로서 상위의 설정을 덮어 쓸수 있다.



 server 엘리먼트

tomcat 서버 구성요소의 정의 부분이다기본값은 <server port="8005" shutdown="shutdown"> 되어 있으며포트 8005 감시하고 shutdown 명령어를 접수하도록 설정되어 있다서버에서는 복수의 서비스를 관련 지울  있다.

 service 엘리먼트

tomcat service 구성요소를 정의하고 있다. <service> 뒤에 기술  <Engine> 그것에 관련된 모든 <Connector> 그룹화  것이다기본값은 <Service name="Catalina"> 되어 있다. (name 으로 "Tomcat-Standalone" 설정하는 경우도 있음)

-> 속성

■ name : Catalina라고 하는이름으로 서비스가 정의 되어 있고에러 로그  관리툴은  이름으로 식별한다.

하나의 서버에 복수의 서비스를 정의하는 경우다른 name 속성을 기입할 필요가 있다 .

<Serice> <Engine> 하나 이상의 <Connector> 관련짓는 것이 가능하다. <Service> <Engine> 관계는 1:1

 Engine 엘리먼트

<Engine> servlet 컨테이너의 인스턴스를 표시하며, <Connector>로부터 보내진 요구를 처리한다. <Engine name="Catalina" defaultHost="localhost"> 되어 있다.

-> 속성

■ name : <Engine> 이름을 표시하며에러 로그  관리툴은  이름으로 <Engine> 식별한다.

■ defaulthost : server.xml 정의 되어 있지 않은 <Host> 요구가 있을 경우 발송되는 가상호스트를 지정한다.

<Engine>에는 하나 이상의 <Host> 관련지어져 있다.

 Connector 엘리먼트

요구를 <Engine> 건네 주는 역할을 하는 것이 <Connector>. <Serviced> 하나 이상의 <Connector> 갖을 필요 있음

사용자는 HTTP 또는 HTTP/SSL  여러가지 방법으로 <Engine> 요구를 보낸다이것들의 접속 요건의 처리는 <Connector>

구성요소에 맡겨진다 프로토콜에 대해 복수의 <Connector> 갖는 것으로서 어떤 접속에서 요구가 보내져와도 <Engine>

 동일하게 처리하고 , 응답을 <Connector> 맡길  있다.

tomcat에는 몇개의 표준<connector> 탑재되어 있으며기본값은 HTTP1.1 <Connector> AJP<Connector> 준비되어 .

 DefaultContext 엘리먼트

모든 <Conext> 고통의 정의부기본적으로 설정되어 있지 않다.

 Realm 엘리먼트

보안을 위해 role명과 사용자명비밀번호의 맵핑을 외부의 데이터베이스로 부터 가져오는 장치다. tomcat UserDataBase, Memory, JDBC, JNDI 몇개의 <Realm> 가지고 있다.

 <Realm> 차이는 어디로 부터 정보를 가져왔는가의 차이밖에 없다기본값으로는 UserDataBase이외의 <Realm> 주석 처리되어 무효로 되어 있다.

 Logger 엘리먼트

로그파일의 작성 방법을 설정한다. <Logger> server.xml 구조에서 보듯이 <Engine>레벨에서 설정할  있다.

<Logger className="org.apache.catalina.logger.FileLogger">

prefix="server-log." suffix=".txt"

timestamp="true"/>

위의 <>에서는 tomcat FileLogger 클래스를 사용, prefix, suffix, timestamp 속성에서 로그파일명을 정의하고 있다 경우로그파일은 [server-log.2008_08.txt] 같은 형식으로 $CATALINA_HOMe/log 디렉토리에 출력된다.

 Host 엘리먼트

<Engine> 관련된 가상호스트를 정의한다.. 기본값으로 다음과 같이 되어 있다.

<Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false">

가상 호스트명을 "localhost" 설정하고 appBase 속성에서 어플리케이션이 탑재되어 있는 디렉토리를 "webapps" 설정하고 있다별도로 unpackWARs에서는 WAR파일을 전개하고나서 실행할 것인지의 여부를 , autoDeploy 속성에서는 tomcat 기동중에 웹어플리케이션을 배치한 경우에 자동으로 읽어 들일 것인지의 여붜를 설정할  있다.

 Value 엘리먼트

tomcat 특유의 기능이다. <Value> 상위 구성요소로의 필터 처리를 담당한다. <Engine>, <Host>, <Context> 관련짓는 것이 가능하다, Tomat에는 표준으로 다음과 같은 몇개의 <Value> 준비되어 있다.

AccessLogValue

<Valve className="org.apache.catalina.valves.AccessLogValve"

directory="logs" prefix="server-log-" fileDateFormat="yyyy-MM-dd" suffix=".txt"/>

RemoteAccessValve

<Valve className="org.apache.catalina.valves.RemoteAddrValve"

allow="127.0.0.1,192.168.0.1" />

SingleSignOnValue

<Valve className="org.apache.catalina.authenticator.SingleSignOn"/>

RequestDumpValue

<Valve className="org.apache.catalina.valves.RequestDumperValve"/>

- AccessLogValue

$CATALINA_HOME/logs 디렉토리에 server-log-2008-08-04.txt  형식으로 로그파일을 작성한다.

- RemoteAccessValue

접근을 IP주소 단위로 제한한다지정주소에서의 접근을 허가거부를 설정할  있다. <>에서는 로컬 IP주소 192.168.0.1 부터의 접근을 허가하고 있다 RemoteHostValue 사용하면 호스트 단위로 접근제한을 설정할  있다.

- SingleSignOnValue

요구와 응답의 헤더와 쿠키를 <Logger> 설정한 로그파일이 작성된다.

 Context 요소

<Host>에는 웹어플리케이션의 복수개의 <Context> 관련지어져 있다. <Context> 요소에는 웹어플리케이션의 일련의 설정 프로퍼티가 들어간다웹어프리케이션 배치에서 소개 한대로  설정은 웹어플리케이션마다에 설정파일을 가질  있다.

- <Logger> 엘리먼트 사용하는 경우

<Logger className="org.apache.catalina.logger.FileLogger"

directory="logs" prefix="localhost_log." suffix=".txt"

timestamp="true"/>

Logger 잠시보면 로거로 FileLogger라는 클래스를 사용할 것이며디렉토리는 톰캣의

logs 디렉토리를 , 파일명은 localhost_log.yyyy-mm-dd.txt 하겠다는 

속성

설명

backgroundProcessorDelay

 값은 컨텍스트와  자식 컨테이너에서 background process method invoke되는delay 시간을 나타낸다.

 값을 양수로 설정하면 어떤 쓰레드가 분기되어 일정 시간 후에  쓰레드가 해당 host 자식 컨테이너에서 background process method 실행시킵니다

만약 설정하지 않으면 디폴트값인 -1 가지며 음수의 값은 부모 host background processing 정책을 사용한다는 것입니다.

참고로 컨텍스트는 세션을 종료하거나 클래스 리로딩을 위한 모니터링등을 위해background processing 사용합니다.

className

사용할 Java 구현체 클래스의 이름 클래스는 반드시 org.apache.catalina.Context인터페이스를 구현해야 합니다지정하지 않으면 표준값 (아래에 정의됩니다) 사용됩니다

cookies

true(디폴트) 지정하면 클라이언트가 쿠키를 지원하는 경우 세션확인의 통신수단(session identifier communication)으로 쿠키를 사용합니다. false 지정하면 세션확인의 통신수단으로 쿠키 사용을 하지 않고어플리케이션에 의한 URL 다시쓰기(URL rewriting)에만 의존한다는 의미입니다.

crossContext

true 지정하면  어플리케이션에서 ServletContext.getContext() 호출을 통해 가상호스트에서 실행중인 다른 웹어플리케이션에 대한 요청디스패쳐(request dispatcher) 성공적으로 얻을  있습니다보안상의 이유로 false(디폴트) 지정하면getContext() 언제나 null 반환하게 됩니다.

docBase

 웹어플리케이션에 대한 Document Base (Context Root로도 알려져 있습니다디렉토리또는 웹어플리케이션 아카이브 파일의 경로명(웹어플리케이션을 WAR 파일로 직접 실행하는 경우) 나타냅니다 디렉토리나 WAR 파일에에 대한 절대경로명을 지정할 수도 있고 Context 정의된 Host appBase 디렉토리에 대한 상대경로명을 지정할 수도 있습니다

override

true 설정하면 DefaultContext element 관련된 host에서 명백하게 상속받아 사용합니다

기본값으로 Defaultcontext element 사용됩니다

privileged

true 설정하면  컨텍스트는 관리자서블릿(manager servlet) 같은 컨테이너 서블릿을사용할  있습니다.

path

 웹어플리케이션의 컨텍스트 경로(context path) 나타내며 요청 URI 시작부분이 컨텍스트 경로와 같을  해당 웹어플리케이션이  요청을 처리하게 됩니다하나의특정 Host 내의 컨텍스트 경로들은 모두 각각 유일해야 합니다만약 컨텍스트 경로를 스트링("")으로 지정하면 Context  Host 대한 디폴트 웹어플리케이션으로정의된 것입니다디폴트 웹어플리케이션은 다른 Context 들에 해당되지 않는 모든 요청을 처리할 것입니다.

reloadable

true 지정하면, Catalina /WEB-INF/classes/ /WEB-INF/lib  클래스 들의 변경여부를 감시하다가변경이 발견되면 웹어플리케이션을 자동으로 재적재(reload)합니다. 기능은 개발중에는 매우 유용하지만 얼마간의 실행부하(runtime overhead) 발생하므로실제 운영할 용도로 어플리케이션을 배치(deploy) 때는 사용하지 않도록 합니다그러나 이미 배치가 끝난 어플리케이션이라도 Manager 웹어플리케이션을 이용하면필요할  재적재 하도록   있습니다

wrapperClass

 Context 관리할 서블릿 들에 대해 사용할 org.apache.catalina.Wrapper 구현체 클래스의 Java 클래스명입니다지정하지 않으면 표준값이 사용됩니다

from http://jakarta.apache.org

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

저자 : GoodBug (unicorn@jakartaproject.com)

최초 : http://www.jakartaproject.com

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

 서블릿 환경설정 (web.xml)

 CATALINA(톰캣 설치 폴더)/conf/web.xml

 invoker 이용하여 모든 서블릿을 호출할  있는 서블릿을 지정합니다.

<servlet>

<servlet-name>invoker</servlet-name>

<servlet-class>

org.apache.catalina.servlets.InvokerServlet

</servlet-class>

<init-param>

<param-name>debug</param-name>

<param-value>0</param-value>

</init-param>

<load-on-startup>2</load-on-startup>

</servlet>

 서블렛을 사용   있도록 환경을 설정하고 Servlet URL상에서의 접근할  있도록 경로명을 지정합니다.

<servlet-mapping>

<servlet-name>invoker</servlet-name>

<url-pattern>/servlet/*</url-pattern>

</servlet-mapping>

 수정된 Servlet,JSP 페이지가 서버를 재시작안해도 인식이 설정

<servlet>

<servlet-name>jsp</servlet-name>

<servlet-class>org.apache.jasper.servlet.JspServlet</servlet-class>

<init-param>

<param-name>modificationTestInterval</param-name>

<param-value>0</param-value>

</init-param>

<init-param>

<param-name>development</param-name>

<param-value>true</param-value>

</init-param>

<init-param>

<param-name>fork</param-name>

<param-value>false</param-value>

</init-param>

<init-param>

<param-name>reloading</param-name>

<param-value>true</param-value>

</init-param>

<init-param>

<param-name>xpoweredBy</param-name>

<param-value>false</param-value>

</init-param>

<load-on-startup>3</load-on-startup>

</servlet>



출처: http://jang8584.tistory.com/72 [개발자의 길]

 style="border-collapse:collapse"

static

static 이란

클래스 필드 또는 메소드 앞에 static 키워드를 사용하므로서 필드, 메소드를 인스턴스의 생성없이 사용 할 수있게한다.

 

목적

모든 인스턴스가 동일 정보를 공유 해야 할때 또는 

메소드가 인스턴스의 데이터와는 상관없이 공통적인 로직이 정의될때

인스턴스마다 할당 된다면 메모리 낭비 뿐만 아니라 데이터를 참조 하거나 호출 할때마다 인스턴스를 생성해야하는등의 번거로움과 인스턴스 메모리해제에 의해 정보손실을 발생시킬 수 있다.

static 을 통하여 이러한 점들을 해결 할 수있다.

인스턴스 생성과정이 없어도 되기때문에 속도 또한 빠르다.

 

 원리

인스턴스가 생성되면 heap 영역에 할당 되어 사용되어진다. 하지만 static 키워드를 붙인 변수와 메소드는 클래스 정보가 할당되는 Method Area에 클래스가 할당 될때 같이 올라가게된다.  heap영역은 가비지 컬렉터의 영향을 받지만 Method Area의 경우 가비지컬렉터의 영향을 받지않고 메모리에 상주 할 수있게 된다.

 

 주의 사항

메모리 누수

static을 통해 메모리가 할당될 경우 클래스가 메모리상에 올라갈때 같이 올라가고 가비지 컬렉터의 영향밖에 있게때문에 프로그램이 종료 될 때까지 메모리를 회수 할 수없다.

신뢰성 하락

static은 언제 어디서든 접근 할 수있다. 그렇기에 언제 어디서 어떻게 변할지 모르는데 멀티스레드 환경에서는 더더욱 static의 상태를 예상하기 어려워진다.

 

어떨때 사용하는 것이 적절할까

상태를 저장하거나 변경하지 않는 경우에 사용하는 것이 적절하다.

예를 들면 Math.PI 에경우 final static 처리되어 상수로 사용되어지고

 Integer.parseInt() 경우 메소드 처리과정에서 어떻한 상태도 변경하지않고 단순히 입력받은 문자열을 정수로 반환 할 뿐이다.


static을 사용하면 편리하기도 하지만 전반적으로 사용을 지양하려는 의견이 많다.

관련 링크




+ Recent posts