반응형

1. Singleton Scope

- SpringContatiner는 해당 Bean에 대한 여러개의 요청이나 참조에 대해 하나의 Bean 인스턴스만 생성해서 제공함.

- 사용자의 요청시마다 유지해야할 data일 경우 Singleton Scope는 부적합.

- scope을 별도로 지정하지 않을경우 기본값은 Singleton Scope이다.


2. Prototype Scope

- SpringContainer는 요청시마다 새로운 인스턴스 생성하여 제공.


3. Request Scope

- Http Request마다 새로운 인스턴스 를 생성하여 제공


4. Session Scope

- Http Session마다 새로운 인스턴스 를 생성하여 제공

728x90
반응형

'Development > Java' 카테고리의 다른 글

[Spring]Autowiring  (0) 2012.05.03
[Spring]AOP 주요 구성요소  (0) 2012.04.13
[Spring]Dependency Injection  (0) 2012.03.21
[Spring in Action]DispatcherServlet 구성  (0) 2011.10.25
[Spring In Action]Spring MVC 요청의 생명주기  (0) 2011.10.17
반응형
Bean Definition 파일에 정의 한 dependency 관련 정보를 바탕으로 객체 사이의 의존 관계를 Container가 자동적으로 연결해주는것을 말한다. Container API 에 종속되는것을 줄일수 있다.
- Setter Injection : Setter 메소드 구현을 통해 해당 객체 초기화시 Container로 부터 참조관계에 놓인 특정 리소스를 할당받음.
- Constructor Injection : Constructor 구현을 통해 특정 객체 초기화 시 Contatiner로부터 참조 관계에 놓인 특정 리소스를 할당 받는 방법

-- Setter Injection 예
[속성 정의 파일 ] 
  1. <bean id="“movieService&quot;" class="….MovieServiceImpl">
  2.    <property name="“genreService&quot;" ref="“genreService&quot;/"></property></bean>
  3.    <bean id="”genreService”" class="”....GenreServiceImpl”/">
  4. </bean>
[구현클래스 ] 
  1. public class MovieServiceImpl implements MovieService{
  2.       DepBean genreService;
  3.       public void setGenreService(GenreService genreService) {
  4.             this.genreService = genreService;
  5.       }
  6. //중략
  7. }
-- Constructor Injection 예
  1. <bean id="“movieService" class="“org.anyframe.exercise.moviefinder.service.impl.MovieServiceImpl">
  2.      <constructor-arg ref="“movieDao/"></constructor-arg></bean>   
  3.      <bean id="movieDao" class="org.anyframe.exercise.moviefinder.service.impl.moviedao"/>
  4. </bean>
[구현클래스 ] 
  1. public class MovieServiceImpl implements MovieService {
  2.       private MovieDao movieDao;
  3.       public MovieServiceImpl(MovieDao movieDao) {
  4.            this.movieDao = movieDao;
  5.      }
  6. }
% Circular Dependencies
  1. <bean id="beanFirst" class="test.BeanFirst">
  2.       <constructor-arg ref="beanSecond"></constructor-arg>
  3. </bean>
  4. <bean id="beanSecond" class="test.BeanSecond">
  5.       <constructor-arg ref="beanFirst"></constructor-arg>
  6. </bean>
 두개의 서로다른 Bean이 constructor-arg 를 이용해 서로의 Bean을 참조하는 경우에 BeanCurrentlylnCreationException 발생


728x90
반응형
반응형
원문 : Don"t blame the information for your bad habits http://www.hanbit.co.kr/network/category/category_view.html?cms_code=CMS6181775366


-----------------------------------------------------------------------------------------------------------------------------------------------------------------------

우리는 이상한 방법으로 우리의 과소비를 비난합니다. 하지만 지나치게 많은 컵케익을 먹는 것은 분명 100% 당신에게 책임이 있습니다. 그러나 만약 당신이 정보의 폭풍, 쓰나미에 의해 휩싸였다면 그건 당신 책임이 아닙니다. 이런 사람들은 자신들이 가지고 있는 통제력 부족이 반영되어있지 않는 한 대량의 무분별한 정보나 전반적인 사회에 대한 비난등에 책임이 있습니다. 정보의 과잉은 항상 누군가의 잘못처럼 여겨집니다. 

"The Information Diet"의 저자 Clay Johnson(@cjoh) 는 정보의 과잉 문제는 실질적으로 정보의 소비 문제라고 이야기 하고 있습니다. 아래 인터뷰에서, Johnson은 어떻게 정보의 소비에 대한 이슈를 재구성하는지 그리고 우리가 습득한 정보에 대한 소유권을 갖는 것이 정보의 균형을 찾는 열쇠라고 설명하고 있습니다. 

"정보 과잉" 는 잘못된 말인가요? 

 Clay Johnson: 정보의 과잉은 잘못된 말입니다. 왜냐하면 그 말은 정보를 탓하고 있기 때문입니다. 정보는 결정을 내리거나 마음씨가 나쁜 어떤 특정한 것이 아니기 때문에 이것은 말이 될 수 없습니다. 정보는 사람들에 의해 만들어진 결정을 알리는 역할을 합니다. 우리는 과식으로 인한 비만으로 사람들이 고통 받고 있다고 말하지 않습니다. 사람들이 경영하는 회사에서 만든 나쁜 음식은 사람들이 운영하는 회사에 의해 분배가 되고, 사람들이 가지고 있는 돈으로 구매가 됩니다. 밤에 방에서 후라이드 치킨과 시간을 보내면서 그것을 안먹는다고 해서 당신의 콜레스테롤 수치가 나아지지는 않을 것입니다. 

우리가 문제를 어떻게 바라보느냐에 따른 차이 때문에 우리는 그것을 단정 할 수 없습니다. 정보의 과잉은 "컴퓨터에 이 툴들을 설치해 놓으면 당신은 정보 관리를 더 잘 할 수 있을 것이다" 라는 메세지를 줍니다. 이런 종류의 훈련은 다른 종류의 냉장고를 구입해서 음식 다이어트를 시도하려는 것, 또는 오로지 구입한 런닝화에 의존해서 전문적인 운동선수가 되려고 하는 것과 같습니다. 문제는 우리가 정보를 관리할 필요가 없다는 것입니다. 우리에게 필요한 것은 정보를 이용하는 방법을 아는 것입니다. 다시 말해, 우리는 수많은 정보들 때문에 고통받는 것이 아니라, 정보를 지나치게 많이 사용하거나 정보를 잘못 이용하는 습관 때문에 고통 받는 것입니다. 해결책은 성공적인 음식 다이어트만큼 간단합니다. 스스로 습관을 만들고 올바른 선택을 해서 계속 지속해 나가면 됩니다. 

왜 우리는 정보 그 차체를 탓하고 있을까요? 

Clay Johnson: 정보는 우리가 생존하기 위해 필요한 3가지, 음식, 물, 공기와는 다릅니다. 신비스러운 힘이 있어야 만들 수 있는 음식, 물, 공기와는 달리 정보는 지극히 쉽게 그리고 어디에서든지 우리에게 생길 수 있습니다. 정보는 우리가 의식적으로 사용하는 것이라고 생각하는 것보다 훨씬 어렵습니다. 확실히 우리의 정보 사용에 대해 책임을 지는 것보다 정보를 탓하는 것이 더 쉽습니다. 또한, 올바른 결정을 하기 위해 우리에게 알려지고 권한을 주는 정보를 추구하는 것보다 오히려 우리의 믿음을 확실히 해주고, 우리를 기쁘게 해주거나 슬프게 하는 정보를 중요하게 생각하는 경제 시스템을 걱정하는 것이 더 쉽습니다. 의식적으로 우리가 정보를 이용하는 것에 대해 인식하려고 하는 것보다 부기맨에 대해 생각하는 것이 더 쉽습니다. 

정보의 무분별한 사용이 육체적 정신적으로 미치는 영향은 무엇인가요? 

 Clay Johnson: 이 책은 제가 생각한 정보의 무분별한 사용에 대한 두 가지 예로 시작합니다. 그리고 제가 책 속에서 해결하려고 했던 가장 큰 문제점은 정부와 완전히 단절된 유권자에 대한 것이었습니다. 2009년 백악관 앞에서 "의료보험 제도에 정부는 손을 떼라"라는 피켓을 들고 시위를 하는 사람을 보았습니다. 또, 얼마 지나지 않아서, Walter Reed 육군 앞에서 "Enlist Here to Die for Halliburton."라는 피켓을 들고 시위하는 사람을 보았습니다. 현재 이 시위들은 어떠한 효과도 거두지 못했습니다. 당신은 정부가 운영하는 프로그램을 중지시킬 수 없으며 육군 병원에서 누구에게도 육군에 지원하라고 요청할 수 없습니다. 그러나 이런 종류의 메세지들 뒤에 숨어있는 사람들과 대화를 한 후에 그들이 어리석다고 여겨지지는 않았습니다. 예를 들어, 앞에서 말한 의료지원에 대한 시위를 했던 사람은 Jekyll 섬에서 연방준비은행의 건립에 대한 45분간의 연설을 통해 10건의 헌법을 수정한 최초의 사람으로 이름을 올릴 수 있었습니다. 이 결과는 나에게 정보의 부족보다 오히려 정보를 사용한 결과에서 나오는 무지의 한 가지 형태라고 생각하게 만들었습니다. 그리고 아니나 다를까, 그러한 관점에서 우리의 역사를 돌이켜 보았을 때, 20세기 초 담배 논쟁에서부터 오늘날 기후변화 및 백신 논쟁까지 수많은 문제점들을 찾을 수 있습니다. 다시 말해, 정보의 잘못된 사용은 민주주의를 저울질 할 수 없게 만들 수 있습니다. Thomas Jefferson은 "한 나라가 무지한채로 자유롭기를 기대하는 것은 과거에도 없었고 미래에도 없는 것을 기대하는 것이다" 라고 말했습니다. 잘못된 정보의 사용은 교육을 제대로 받지 못한 것 만큼 무지를 가져올 수 있습니다. 정보의 잘못된 사용은 시간 관념이 없는 사람처럼 여겨지거나 주의력이 없고 피상적인 관계만을 추구하는 사회 구성원으로 여겨지는 각각 다른 종류의 결과를 가져옵니다. 스트레스, 고혈압, 주로 앉아서 지내는 생활습관 등이 비웃을만한 일이 아니라는 것을 기억해야만 합니다. 우리는 조용히 아무말 없이 명상을 하고 있기 때문에 한 곳에 머물러 있는 것이 아닙니다. 우리는 너무 많은 정보를 사용하고 있기 때문에 종종 한 곳에 머물러 있기도 합니다. 

정보의 잘못된 사용을 막기 위해 우리가 해야 할 첫 번째 할 일은 무엇일까요? 

Clay Johnson: 첫번째 할 일은 정보를 측정하는 것입니다. 음식을 먹을 때 어느 정도가 적당한 양인지 생각하는 것은 좋은 방법입니다. 시스템 전원, 페이지, 스위치, 탭, 또는 마우스 클릭 등을 포함해서 당신이 갖기를 원했던 정보를 찾기 위해 했던 행동들을 측정해 보십시오. 당신은 잠을 잘 때 숙면을 취하기 위해 여러가지 방법을 사용할 것입니다. 그러나 그런 것들이 당신이 깨어있을 때에도 도움을 주지는 않습니다. 컴퓨터에 RescueTime 같은 서비스를 이용해서 당신이 행하는 모든 것들을 기록하십시오. 그리고 컴퓨터를 사용하지 않을 때에는 작은 매체를 사용하십시오. 

두번째는 케이블 TV를 중단하는 것입니다. 케이블 스포츠 패키지를 시청하면서 정보 다이어트를 한다는 것은 매일매일 프라이드치킨과 아이스크림 배달을 시켜 먹으면서 체중을 줄이려는 것과 같습니다. 케이블 tv를 중단하는 것에는 2가지 목적이 있습니다. 아마도 정보 중에 가장 쓸모없는 광고에 노출되는 것을 줄일 수 있고 당신의 능력이 TV 앞에 앉아있는 채로 무의미하게 사용되는 것을 줄일 수 있습니다. 또한 돈을 절약할 수도 있습니다. Netflix, Hulu, iTunes , Amazon 등 오직 인터넷만 이용함으로써 많은 돈이 절약 될 것입니다. 

세번째는 정보를 이용하는 습관을 바꾸는 것입니다. 음식 습관처럼 가까운 곳에서부터 하는 것이 좋습니다. 당신이 가장 쉽게 접근할 수 있는 정보들부터 시작해야 합니다. 당신과 가장 가까운 가족, 친구들, 그리고 나서 지역 또는 전문적인 모임, 마지막으로 국가적, 국제적 이슈들을 다루는 것이 좋습니다. 우리 지역 교육 위원회와 우리에게 가장 중요한 영향을 미치는 결정을 하는 주 의회의 경우 워싱턴 또는 세계의 이슈에 대해 너무 집중하는 경향이 있습니다. 

네번째는 당신의 컴퓨터를 고치는 것입니다. 컴퓨터에 의한 숫자를 없애려고 노력해야 합니다. Google+에서 볼 수 있는 빨간 알림 상자, 노래를 들을 때에도 당신에게 팝업으로 알려주는 것들, 모든 알림 팝업들, 이것들이 당신의 받은 편지함 숫자입니다. 그것들을 모두 제거하십시오. 그리고 당신 컴퓨터에서 하는 일에 집중하기 위해 노력해야 합니다. 컴퓨터는 구글, 마이크로소프트, 페이스북의 것이 아닌 당신의 것입니다. 여전히 사람들은 깨어있는 동안 눈앞에 보이는 것을 얻기 위해 끊임없이 전쟁을 하고 있습니다. 여기 당신 시스템 알람 제거를 도와줄 자료와 팁 목록을 같이 마련해 놓았습니다. 

다섯번째로, 나이 드신 분들이 알아들을 수 없을 것 같은 정보를 사용하지 않는 것입니다. 고도로 처리된 자료는 피해야 하고 자료와 직접 맞닿아야 합니다. 독자와 시청자들에게 원본 자료에 대한 권한을 주지 않는 뉴스 기사는 피해야 하고 당신 스스로 적극적으로 원본 자료를 찾아야 합니다. 

정보의 사용을 당신이 통제할 수 있다는 것을 어떻게 알 수 있나요? 

Clay Johnson: 처음 제가 이런 일을 했을 때, 특히 광고와 내 일정 알람을 지운 후에는 마치 제 몸무게가 줄어든것 같은 느낌이 들었습니다. 당신 자신이 고통 받고 있다는 것을 깨닫기 전까지는 아주 시끄러운 에어컨이 놓여있는 방에 있는 것처럼 느껴집니다. 하지만 그 에어컨을 끄고 나면 안도의 한숨을 쉴 수 있습니다. 불행하게도 이것은 당신의 뇌에 그 다음 도파민이 도달하여 뇌가 걱정하기 시작하기 전까지라는 아주 짧은 시간 동안 지속됩니다. 그러나 그 상태를 유지시키려고 하십시요. 저의 경우에, 약 1년동안 정보의 다이어트를 한 후, 제 아내와 가족과 더 많은 시간을 보낼 수 있다는 것을 깨닫게 되었고, 일을 더 잘 하게 되었으며 전반적으로 스트레스도 덜 받게 되었습니다.

728x90
반응형
반응형
오라클 10g부터 정규 표현식을 사용할수 있게 되었다ㅏ. 
REGEXP_SUBSTR 란 키워드이다. 아주 간편하게 필터링 할수 있다. ㅎㅎ

WITH TEMPTABLE AS 
       (SELECT IF_FILE_NM 
         FROM 
              (SELECT 'L6D0POMTK00020111116133559.txt' AS IF_FILE_NM 
                FROM DUAL 
                  UNION 
              SELECT '1K010POMPKP1020111117134202.txt' AS IF_FILE_NM 
                FROM DUAL 
                  UNION  
              SELECT 'W100W10002POMT20111122131003.txt' AS IF_FILE_NM 
                FROM DUAL  
                  UNION 
              SELECT 'E10000SWPOMT20111114232235_7942630.txt' AS IF_FILE_NM 
                FROM DUAL 
                  UNION 
              SELECT 'H10000GJPOMT201111221532409511.txt' AS IF_FILE_NM 
                FROM DUAL 
                  UNION 
              SELECT '1M114POMT20111122-184314-487.txt' AS IF_FILE_NM 
                FROM DUAL  
                  UNION 
              SELECT '1M114POMT20111122-221352-383.txt' AS IF_FILE_NM 
                FROM DUAL  
                  UNION 
              SELECT 'POGLNTIMK0.GDS.20111114222035' AS IF_FILE_NM 
                FROM DUAL 
              )  
       ) 
SELECT SUBSTR(REPLACE((REGEXP_SUBSTR(IF_FILE_NM , '([1-9]{1}[0-9]{13}|[1-9]{1}[0-9]{13}_[0-9]{7}|[1-9]{1}[0-9]{13}[0-9]{4}|[1-9]{1}[0-9]{7}-[0-9]{6}-[0-9]{3}).[a-zA-Z]{3}|[1-9]{1}[0-9]{13}$')),'-''' ) ,0 ,14) AS FILE_CRE_YMD 
  FROM TEMPTABLE


728x90
반응형
반응형

원문 : A look at Java 7"s new features 


------------------------------------------------------------------------------------------------------------------------------------------------------------------------

Java 7에는 개발자들이 좋아할만한 많은 특징들이 있다. switch구문에서 사용하는 String, 다중 exception처리multi-catch exception), try-with-resource 구문, 새로운 파일시스템 API, JVM의 확장, 동적 타입의 언어에 대한 지원, 유사한 작업을 위한 fork와 join 프레임워크 등 분명히 많은 곳에서 수용되어질 것이다. 

아래에 Java 7의 특징을 설명하고 예제를 제공하였다.. 이 글에서 사용한 코드가 담긴 zip파일은 이곳에서 다운로드 받을 수 있다.

개선된 점들

Java 7은 Project Coin을 통한 새로운 특징을 포함하고 있다. 이 특징들은 개발자들에게 상당히 유용하다. 

다이아몬드(<>) 지시자 

당신은 사용하고 있는 IDE에 대한 불평으로 Generics를 사용한 경우를 많이 언급해왔을 것이다. 예를 들면 우리가 Map을 이용한 Generics를 선언할 때에 아래와 같이 코드를 작성할 것이다.

Map> trades = new TreeMap> ();

이런 선언에 대한 안 좋은 점은 오른쪽에 있는 선언이 불필요하게 보일지라도 우리는 양쪽에 타입을 선언해야만 한다는 것이다. 왼쪽에만 선언한 것으로 컴파일러가 타입을 추측할수 있을까? Java 7을 사용하지 않으면 불가능하다. Java 7에서는 아래와 같이 작성한다.

Map> trades = new TreeMap <> ();

얼마나 멋진가? 당신은 인스턴스를 생성하기 위해서 전체 타입을 입력할 필요가 없다. 대신 다이아몬드 지시자라고 불리는 <> 기호를 사용한다. trades = new TreeMap() 과 같이 다이아몬드 지시자를 선언하지 않는 것은 허용되지만 컴파일러가 Type safety warning을 발생시킨다. 

switch 구문에서 String 사용 

Switch 구문은 기본형과 열거형만 사용이 가능했다. Java 7은 switch 문에서 사용할수 있는 다른 타입을 추가하였다. 바로 String 타입이다. 

Trade의 상태로 진행되는 요구사항이 있다고 해보자. 지금까지는 이러한 상황에서 if-else구문을 사용해왔다.

private void processTrade(Trade t) {
  String status = t.getStatus();
  if (status.equalsIgnoreCase(NEW)) {
    newTrade(t);
  } else if (status.equalsIgnoreCase(EXECUTE)) {
    executeTrade(t);
  } else if (status.equalsIgnoreCase(PENDING)) {
    pendingTrade(t);
  }
}

String으로 동작하는 이 메서드는 대충 만들었다. Java서에서 우리는 String 타입을 변수로 받는 향상된 Switch문을 활용하여 이 메서드를 향상시킬수 있다.

public void processTrade(Trade t) {
  String status = t.getStatus();
  switch (status) {
    case NEW:
  newTrade(t);
  break;
    case EXECUTE:
  executeTrade(t);
  break;
    case PENDING:
  pendingTrade(t);
  break;
    default:
  break;
  }
}

위에 프로그램에서는, 상태 필드를 계속 String.equals() 메서드를 사용한 case label과 비교하였다. 

자동 자원 관리 

Connection, Files, Input/OutStream 등과 같은 자원은 코드를 작성한 개발자가 수동으로 회수해야만 했다. 보통 우리는 각각의 자원을 회수하기 위해 try-finally 블록을 사용한다. 아래 예제를 보면 리소스를 만들고, 그것을 사용하고 마지막에는 그것을 회수한다.

public void oldTry() {
  try {
    fos = new FileOutputStream("movies.txt");
    dos = new DataOutputStream(fos);
    dos.writeUTF("Java 7 Block Buster");
  } catch (IOException e) {
    e.printStackTrace();
  } finally {
    try {
  fos.close();
  dos.close();
    } catch (IOException e) {
  // log the exception
    }
  }
}

그러나, Java 7은 자동으로 리소스를 관리하는 훌륭한 기능을 소개하고 있다. 동작 또한 간단하다. 우리가 해줄 것은 try문 안에 아래와 같이 자원을 선언하는것 뿐이다.

try(resources_to_be_cleant){
  // your code
}

예전 try문을 사용한 위의 메소드는 아래 보여지는 것처럼 이 새로은 기능을 사용하여 다시 작성될 수 있다.

public void newTry() {
  try (FileOutputStream fos = new FileOutputStream("movies.txt");
  DataOutputStream dos = new DataOutputStream(fos)) {
    dos.writeUTF("Java 7 Block Buster");
  } catch (IOException e) {
    // log the exception
  }
}

위의 코드는 또한 이 특징의 다른 측면도 보여주고 있다 : 여러개 자원들에 대해서도 동작을 한다. FileOutputStream과 DataOutputStream 은 각각 세미콜론(;)으로 나눠서 차례로 try 문 안에 쌓여있다. 

try블록에 존재하는 기능이 한번에 자동으로 스트림을 회수해주기 때문에 우리는 수동으로 스트림을 null 처리하거나 close해줄 필요가 없다. 자동으로 회수되어져야 하는 자원들은 내부적으로 java.lang.AutoCloseable 인터페이스를 구현 해야만 한다. 

AutoCloseble 인터페이스를 구현한 리소스들은 자동 자원 관리를 위한 지원자가 될 수 있다. AtutoCloseable은 java.io.Closeable 인터페이스의 부모이고 오직 close() 메서드 하나만을 가지고 있다. 이 close() 메서드는 try 블록이 나왔을 때에 JVM에 의해서 호출된다. 

숫자와 관련된 문자에 밑줄 표시 

숫자와 관련된 문자들은 분명히 눈 여과기이다. 만약 10개의 0이 있는 숫자가 있다면 당신은 나와 마찬가지로 0을 세어보기 시작할 것이다. 만약 100만 또는 10억의 숫자가 있는데 당신이 오른쪽에서 왼쪽으로 자릿수를 세어보지 않는다면 문자를 인식하는데 실수를 범하기 쉽고 어려울 것이다. 더이상 그럴 필요가 없다. Java 7에는 자릿수를 표시하기 위한 underscores(밑줄)이 포함되어있다. 예를들어, 아래와 같이 1000을 선언 할 수 있다.

int thousand =  1_000;

1000000은 아래와 같다.

int million  =  1_000_000

이번 릴리즈에는 2진수에 대한 것도 소개 되었다. 예를 들어 "0b1"과 같이 2진수도 표현할 수 있어서 개발자들이 더 이상 16진수로 이것을 변환하지 않아도 된다. 

향상된 예외처리 

예외처리 영역에서 2가지 향상된 점이 있다. Java7에서는 하나의 catch블록을 사용해서 여러개의 예외를 처리하기 위한 multi-catch 기능을 소개하고 있다. 

3개의 예외를 처리 해야하는 메서드가 있다고 가정해보자. 현재 상태에서는 아래처럼 각각의 예외를 처리해야 한다.

public void oldMultiCatch() {
  try {
    methodThatThrowsThreeExceptions();
  } catch (ExceptionOne e) {
    // log and deal with ExceptionOne
  } catch (ExceptionTwo e) {
    // log and deal with ExceptionTwo
  } catch (ExceptionThree e) {
    // log and deal with ExceptionThree
  }
}

catch 블록 안에 여러개의 예외를 차례로 처리하는 모습은 어수선해 보인다. 나는 12개의 예외를 잡는 코드를 본적도 있다. 이것은 믿을 수 없을 정도로 비효율적이고 오류를 범하기 쉽다. Java 7은 이 미운 오리새끼를 다루기 위해 언어에 새로운 변화를 가져왔다. 아래에 oldMultiCatch 메서드의 향상된 버전을 보자.

public void newMultiCatch() {
  try {
    methodThatThrowsThreeExceptions();
  } catch (ExceptionOne | ExceptionTwo | ExceptionThree e) {
    // log and deal with all Exceptions
  }
}

여러개의 예외들은 "|" 연산자를 사용해서 1개의 catch블록 안에서 처리된다. 이 방법으로 더이상 12개의 catch문을 작성할 필요가 없다. 그러나 다른 타입에 속하는 여러 개의 예외가 있다면 "multi multi-catch" 블록을 이용하면 된다. 아래 예제에는 이 내용을 보여주고 있다.

public void newMultiMultiCatch() {
  try {
    methodThatThrowsThreeExceptions();
  } catch (ExceptionOne e) {
    // log and deal with ExceptionOn
  } catch (ExceptionTwo | ExceptionThree e) {
    // log and deal with ExceptionTwo and ExceptionThree
  }
}

다른 분류에 속하는 ExceptionTwo와 ExceptionThree는 다르게 분리되었지만, 하나의 catch블록에서 처리되어있다.

새로운 파일 시스템 API (NIO 2.0)

Java IO를 사용한 많은 사람들은 여전히 프레임워크에 의해서 발생되는 골치 거리들을 기억할 것이다. 운영체제나 다중파일 시스템에서 동일하게 적용하기 정말 어렵다. 대부분 예기치 않게 발생된 delete나 rename 메서드가 그런 경우이다. 특정 기호로 연결되어 작동하는 것은 다른 문제이다. 본질적으로 API는 정비가 필요하다. 

Java IO에서 나타난 위의 문제점들을 풀기 위해서 Java 7은 정비된 많은 종류의 새로운 API를 도입하였다. 

NIO2.0은 많이 향상된 점을 가지고 나왔다. 또한 다중파일시스템으로 작업하는 개발자의 삶의 불편을 덜어주기 위해 새로운 클래스들을 도입하였다. 

Path를 이용한 처리 

새로운 java.nio.file 패키지는 Path, Paths, fileSystem, FileSystems 등과 같은 클래스와 인터페이스로 구성되어있다. 

Path는 단순이 file 경로의 참조이다. java.io.File과 비슷하다(더 많은 특징을 가지고 있다). 아래에서는 temp 폴더의 참조 경로를 어떻게 획득하는지를 보여주고 있다.

public void pathInfo() {
  Path path = Paths.get("c:\Temp\temp");
  System.out.println("Number of Nodes:" + path.getNameCount());
  System.out.println("File Name:" + path.getFileName());
  System.out.println("File Root:" + path.getRoot());
  System.out.println("File Parent:" + path.getParent());
}

실행 결과는 다음과 같다.

Number of Nodes:2
File Name:temp.txt
File Root:c:
File Parent:c:Temp

파일이나 디렉토리를 삭제하는 것은 Files 클래스에 있는 delete 메서드를 호출하는 것만큼 간단하다. Files 클래스는 NoSuchFileException을 처리하는 것과 처리하지 않는 2개의 delete 메서드를 가지고 있다. 

아래에 delete 메서드 호출은 NoSuchFileException을 던진다. 따라서 해당 exception을 처리해야만 한다.

Files.delete(path);

만약 file 또는 디렉토리가 존재하지 않는다면 예외를 던지길 기대하더라도 Files.deleteIfExists(path)은 예외를 던지지 않는다. 

파일 시스템에서 효과적으로 동작하는 Files.copy(..)나 Files.move(..)와 같은 유용한 메서드를 사용할수 있다. 당신의 코드에서 링크를 만들때에 단순히 createSymbolicLink(..) 메서드를 사용하면 된다. 

알림을 변경한 File 

JDK7에서 가장 마음에 드는 점은 File Change Notifications의 추가이다. 아주 오랫동안 기다려왔던 이 기능은 마침내 NIO 2.0에 추가되었다. 

API를 구현하는데 관련된 단계는 아래와 같다.

  • WatchService를 생성한다. 이 서비스는 WatchKeys를 가지고 있는 큐로 구성되어있다.
  • 이 WatchService로 모니터링하고 싶은 디렉토리나 파일을 등록한다.
  • 등록하는 동안 받고 싶은 이벤트의 타입을 정의한다. (추가, 수정, 삭제등)
  • 이벤트를 받기위해 무한대 루프를 실행시켜야만 한다.
  • 이벤트가 발생하면 WatchKey 가 큐안으로 저장된다.
  • WatchKey를 사용하기 위해 쿼리를 호출한다.

다음 예제를 통해서 따라해보자. 우리는 특정 디렉토리를 감시하는 DirPolice 자바 프로그램을 만들것이다. 방법은 아래에 제공되어있다. 

1. WatchService 객체를 생성한다.

WatchService  watchService = FileSystems.getDefault().newWatchService();

2. 볼수있는 디렉토리의 참조경로를 가져온다. 나는 파일명을 하드코딩하지말고 파라메터로 전달하기를 추천한다.

path = Paths.get("C:\Temp\temp\");

3. 다음 단계는 모든 종류의 이벤트를 WatchService 에 등록한다.

dirToWatch.register(watchService, ENTRY_CREATE, ENTRY_MODIFY, ENTRY_DELETE);

이 타입들은 java.nio.file.StandardWatchEventKinds 에 정의된 이벤트 타입들이다. 

4. 무한 루프를 초기화하고 이벤트를 잡기위해 시작시킨다.

while(true)
{
  WatchKey key = watchService.take(); // this would return you keys
}

5. 키 이벤트들을 통해 실행된다.

for (WatchEvent event : key.pollEvents()) {
  Kind kind = event.kind();
  System.out.println("Event on " + event.context().toString() + " is " + kind);
}

예를들어, temp 디렉토리를 수정하거나 삭제하면 콘솔창에 각각 아래와 같은 문장을 보게 될것이다.

Event on temp is ENTRY_MODIFY 

Event on temp is ENTRY_DELETE

DirPolice 소스와 과련된 메서드는 아래에 게시되어있다. (전체 소스코드 다운로드)

/**
 * This initiates the police
 */
private void init() {
  path = Paths.get("C:\Temp\temp\");
  try {
    watchService = FileSystems.getDefault().newWatchService();
    path.register(watchService, ENTRY_CREATE, ENTRY_DELETE,
        ENTRY_MODIFY);
  } catch (IOException e) {
    System.out.println("IOException"+ e.getMessage());
  }
}

/**
 * The police will start making rounds
 */
private void doRounds() {
  WatchKey key = null;
  while(true) {
    try {
      key = watchService.take();
      for (WatchEvent event : key.pollEvents()) {
        Kind kind = event.kind();
        System.out.println("Event on " + event.context().toString() + " is " + kind);
      }
    } catch (InterruptedException e) {
      System.out.println("InterruptedException: "+e.getMessage());
    }
    boolean reset = key.reset();
    if(!reset)
      break;
  }
}


Fork와 Join

Java 프로그램에서 병렬코어들을 효과적으로 사용하는것은 항상 도전이었다. 여러개의 코어에 작업을 나눠주고 결과를 리턴받기위해 그것들을 조인하는 소수의 프레임워크들이 있다. Java7은 Fork와 Join 프레임워크로 이 기능들을 포함했다. 

기본적으로 소규모 작업이 더 이상의 분할이 없이 해결될 수 있을 때까지 Fork-Join은 작업들을 소규모로 나눈다. divide-and-conquer 알고리즘과 비슷하다. 이 프레임워크에서 주목할만한 중요한 개념은 원칙적으로 worker thread는 더이상 유휴상태일리가 없다는 것이다. 바쁜 worker들로부터 작업을 "훔친다" 는 것은 이 프레임워크가 work-stealing algorithm를 구현했다는 것이다. 

Fork-Join 메카니즘을 지원하는 코어 클래스들은 ForkJoinPool과 ForkJoinTask이다. 

ForkJoinPool 은 기본적으로 위에서 말했던 work-stealingalgorithm을 구현한 ExecutorService를 특화시켜서 구현한것이다. 

우리는 수많은 프로세서들을 동일한 레벨의 대상으로 제공함으로써 ForkJoinPool 객체를 생성한다.

ForkJoinPool pool = new ForkJoinPool(numberOfProcessors)

여기서 numberOfProcessors = Runtime.getRunTime().availableProcessors(); 

그러나 ForkJoinPool의 기본 인스턴스는 위에서 얻은 동일한 개수로 동일한 단계로 설정 해야 한다. 

해결해야 할 문제는 ForkJoinTask 안에 만들어져 있다. 그러나 RecursiveAction 과 RecursiveTask 클래스는 특별하게 구현되어 있다. 이 2개 클래스의 차이점은 앞에것은 리턴값이 없는 반면에 뒤에것은 특정 타입의 오브젝트를 리턴한다는 것이다. 

여기 당신의 요구사항을 나타낸 RecursiveAction 와 RecursiveTask 클래스를 어떻게 생성하는지 보여주고 있다.(나는 RecursiveAction 클래스를 사용했다.)

public class MyBigProblemTask extends RecursiveAction {
  @Override
  protected void compute() {
    . . . // your problem invocation goes here
  }
}

당신은 computing 기능을 필요하는 곳에 compute 메서드를 오버라이드 해야한다. 그리고 ForkJoinPool 안에 있는 호출 메서드 부름으로써 ForkJoinTask를 Executor에 전달한다.

pool.invoke(task);


동적 언어 지원

Java는 변수, 메서드와 반환값들의 타입을 컴파일 시간에 체크하는 정적인 유형의 언어이다. JVM은 타입정보를 찾는것에 대한 우려 없이 런타임시간에 강력히 정의된 바이트 코드를 실행시킨다. 

동적으로 타입이 정해지는 다른 유형의 언어들이 있다. Ruby, Python, Clojure 는 이 분류에 속한다. 이 언어들은 타입이 실행시간때까지 정해지지 않는다. 어떤 필요한 타입의 정보를 가지고 있지 않다는것은 Java에서는 불가능하다. 

동적 언어를 효과적으로 실행하는 것을 임시적으로 처리한것에 대한 자바진형에 압력이 증가하였다. 이들 언어들을 JVM에서 실행하는 것이 가능할지라도, 제약과 제한이 없는 것 은 아니었다. 

Java7에 있는 동적호출이라는 새로운 기능을 소개하였다. 이것은 자바 이외의 언어의 요구사항을 포함하기 위해 가상머신을 변경하여 만든것이다. java.lang.invoke 라는 새로운 패키지는 MethodHandle, CallSite등과 같은 클래스로 구성되어있고 동적 언어에 대한 지원을 확장하기 위해 만들어졌다.

마무리

우리가 알아본 Java7은 개발자의 얼굴을 웃음짓게 할 몇 가지 부가 기능들을 가지고 있다. 그리고 오픈소스 지원과 JVM 확장을 통한 동적언어 지원은 자바 진형 이외의 개발자들에게도 좋은 평가를 받을것임에 틀림없다.

728x90
반응형
반응형
기존에 세로로 나온 DATA를 가로로 바꿀때에는 쿼리가 복잡했었지만 오라클 11g에서는 LISTAGG라는 함수를 사용해서 간단하게 만들수 있다. 

WITH RGN AS 
       (SELECT RGN_CD 
         FROM 
              (SELECT 'A' AS RGN_CD 
                FROM DUAL 
                  UNION 
              SELECT 'B' AS RGN_CD 
                FROM DUAL 
                  UNION 
              SELECT 'C' AS RGN_CD 
                FROM DUAL 
                  UNION 
              SELECT 'D' AS RGN_CD 
                FROM DUAL 
                  UNION 
              SELECT 'E' AS RGN_CD 
                FROM DUAL 
              ) 
       )  
SELECT LISTAGG(RGN_CD, ',') WITHIN GROUP (ORDER BY RGN_CD)AS RGN_CD 
  FROM RGN

결과
RGN_CD
--------
A,B,C,D,E 

쿼리도 복잡하지 않고 정말 한줄에 끝난다.!! 


728x90
반응형
반응형
  1. <servlet>
  2.     <servlet-name>actionServlet</servlet-name>
  3.     <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
  4.     <load-on-startup>1</load-on-startup>
  5. </servlet>
DispatcherServlet이 로드되면 이 서블릿에 부여된 이름을 기반으로 이름지어진 XML 파일을 이용하여 스프링 어플리케이션 컨텍스트를 로드한다. (actionServlet-servlet.xml) 
  1. <servlet-mapping>
  2.     <servlet-name>actionServlet</servlet-name>
  3.     <url-pattern>*.html</url-pattern>
  4. </servlet-mapping>
html로 끝나는 모든 URL 처리 
  1. <listener>
  2.     <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
  3. </listener>

컨텍스트 로더 구성 

ContextLoaderListener 구성후에 설정파일 위치 지정해야한다. 지정하지 않으면 /WEB-INF/applicationContext.xml을 검색하게 된다. 

  1. <context-param>
  2.     <param-name>contextConfigLocation</param-name>
  3.     <param-value>classpath:webservice/*-webservice.xml</param-value>
  4. </context-param>


728x90
반응형
반응형


1. 요청이 가장 먼저 들르는곳은 DispatcherServlet이다. DispatcherServlet이 프론트 컨트롤러 역할을 한다. 

2. DispatcherServlet은 요청을 스프링 MVC 컨트롤러로 보낸다. 이때 요청을 어느 컨트롤러로 보낼지 알아내기 위해 Handler Mapping에 도움을 청한다. Handler Mapping은 요청에 담긴 URL을 참고해서 결정을 내린다.

3. 컨트롤러가 결정되면 DisspatcherServlet이 요청을 Coltroller로 보낸다. Controller에서는 비지니스 로직을 수행하거나 여러개로 서비스에 비지니스 로직의 책임을 위임하기도 한다. 결론적으로 비지니스로직의 처리가 끝날때까지 기다린다. 처리가 끝난면 브라우저에 표시될 정보가 만들어진다. 이 정보가 Model 이라고한다.

4. Controller는 모델 정보다 이정보를 보여줄 view의 이름을 ModelAndView 객체에 담아 DispatcherServlet으로 돌러 보낸다. 

5. ModelAndView가 DispatcherServlet에 도착하면 ViewResolver에게 실제 view를 보여줄 Jsp 페이지를 검색해줄것을 요청한다. (View 페이지가 Jsp 일 경우) ModelAndView객체에는 실제 Jsp페이지에 대한 레퍼런스를 갖고 있는것이 아니라 뷰를 검색하는데 사용되는 논리적인 이름을 갖고 있다.

6. 마지막으로 view 객체에 모델 데이터를 전달한다. 

728x90
반응형
반응형
- Dirty Read
  Transaction에서 다른 Transaction에 의해 변경됐지만 아직 커밋되지 않은 데이터를 읽어버리는 문제.
  이 데이터가 커밋되지 않고 롤백 됐을경우 첫번째 Transaction에서 읽은 데이터는 유요하지 않은 데이터가 된다.

- NonRepeatable Read
  Transaction이 같은 질의를 2번 이상 수행할때 서로 다른 데이터를 얻기 되는것을 말한다. 
  각 질의 사이에 다른 Transaction이 데이터를 변경하는 경우에 발생한다. 

- Phantom Read 
  Transaction이 둘 이상의 데이터 행을 읽은 다음, 동시에 다른 Transaction이 추가 행을 삽입할때 발생한다.
  첫번째 질의에는 없어떤 행이 두번째 질의에서는 나타나게된다.

Nonrepeatable Read와 Phantom Read 의 차이가 헷갈려서 인터넷을 찾아본 결과, 
Nonrepeatable Read는 Transaction 중간에 Update나 Delete가 끼어들어 데이터의 변형이 일어났을 경우이고
Phantom Read는  중간에 Insert가 수행되어서 행이 추가되는 경우라는 차이가 있다고 한다.  
728x90
반응형

+ Recent posts