'하늘을 사랑한 사람 여행기' 카테고리의 다른 글
전주한옥마을_풍남문 (0) | 2016.05.06 |
---|---|
윤동주 시인님의 언덕에 가다 (0) | 2016.04.09 |
외도 여행 두번째 (0) | 2015.05.31 |
외도여행 첫번째 (0) | 2015.05.31 |
축령산 정상에서 (0) | 2015.02.08 |
전주한옥마을_풍남문 (0) | 2016.05.06 |
---|---|
윤동주 시인님의 언덕에 가다 (0) | 2016.04.09 |
외도 여행 두번째 (0) | 2015.05.31 |
외도여행 첫번째 (0) | 2015.05.31 |
축령산 정상에서 (0) | 2015.02.08 |
이른 사월 새벽 비가 내립니다.
문을 열어 차갑고도 시린 빗방울에 손을 가져가 봅니다.
쫓기듯 떠밀려 온 시간에 대한 아쉬움이 밀려 옵니다.
텅빈 느낌,
텅빈 공간,
일상이 되어 버린 공간 속에 갇혀 익숙해 지기를 반복하다 보니
어느샌가 변화를 거부하고 있었는지 모릅니다.
운명처럼 어떤 사람을 만나고,
또 숙명처럼 헤어져 버리고 난 후
가슴 속에는 그 사람과의 따스했던 온기가 남습니다.
미워서 싫다 말해도 가슴엔 늘 고마움이 따라다닙니다.
그 사람이 있었기 때문에 느낄 수 있었던
한 두가지 의미를 되새겨 봅니다.
새벽 네시 무심하게도 하늘에서는 비가 내립니다.
어제는 함박 펼쳐진 벚꽃을 한아름 기억 속에 깔았었는데,
아마도 시린 빗방울이 환하게 웃던 벚꽃잎을 땅위로 떨구겠죠.
어디론가 흘러서 정지하는 공간에 스르르 옛날이 되어 가겠죠.
멍해져 버린 머리 사이로
정말 멍해져 버린 텅빈 감성이 가슴을 깨웁니다.
뭐하는 건가 친구,
사랑을 찾기를 바라는가?
아니면 특별한 만남을 계획하고 있는가?
아니, 그냥 또렷한 현실 앞에 서 있다네.
그리고 무심하게도 시리고도 시린 봄비가 내리고 있다네.
가슴 깊은 곳으로 파고 드는 정적이 있다.
어떤 또렷한 형체도 아닌,
어떤 흐릿한 형체도 아닌 것,
나는 누구일까?
이런 물음이 부질 없어 보일 수도 있다.
나란 어떤 존재일까?
어디를 향해 가고 있는 것일까?
이 세상의 끝에서 만나는 의미는 어떤 것일까?
의문에 의문이 꼬리를 물고 길게 늘어져 간다.
분명 이 지구에 온 목적은 있을 것 같다.
누구를 위해 온 것은 아니다.
내 자신을 위해 온 것이며,
내 자신을 바로 알기 위해 이 땅위에 선 것이다.
나는 나를 알기 위해 탐구하고 있으며,
다소 모호한 경계에 있는 미지를 밝히기 위해 서 있다.
그렇다면,
이 세상 끝나는 지점에서 얻게 되는 것은
결국 남들에게 보여지는 이 형체가 아닐 것이다.
궁극의 것을 찾는다.
궁극의 것을 느낀다.
궁극의 것,
궁극은 결국 내 자신이 찾아야 하는 미지이다.
외롭거나 두렵거나 좌절할 필요는 없다.
그 과정이 결국 궁극의 의미를 보려고 찾아가는 여정일테니.
봄날이라 부르는 시점에 서 있다.
여기 서서 무한히 펼쳐진 하늘을 응시한다.
저 너머에 또다른 내가 나를 응시하고 있을 것이다.
언젠가 뒤바뀌게 될 입장,
언젠가는 서로가 가진 꿈이 현실과 비현실 사이를 가르게 될 것이다.
공백,
그 공백이 바로 지금이며,
그 공백을 뛰어 넘어 만나게 될 몇년 후의 나를 기다린다.
그 공백을 뛰어 넘어 만나게 될 내 사랑을 기다린다.
그 공백 뒤에 아장 아장 걷는 아이의 모습을 기다린다.
공백,
기억상실증이란 마법에 빠져버렸다.
스치듯 일부분씩 머리를 어지럽힌다.
하늘나라 꿈은 가볍다.
그곳에 도착하려면
수북히 쌓여진 일상을 지나야한다.
검게 불이 꺼진 공간
중국어를 하는 한 사나이가
칼로 가슴을 찌르는 꿈을 꿨다.
검은 기둥 앞에 검붉은 피를 흘리며
쓰러진 나를 바라본다.
쓰러진 건 망각하는 자아이다.
자아의 붕괴,
괴로워하며 꿈을 내달린다.
두 눈을 떴을 때
수술대 위에 올려져 있는 내 자신을 발견한다.
흐릿한 정신에 맑은 기운이 흐른다.
손으로 허공을 부여잡고 일어난다.
악몽이다.
잠시 후면 깨끗하게 사라질 꿈이다.
잠시 망각하고
잠시 기억을 더듬는 인간이란
미완으로 만들어져 있다.
뚜~뚜우-삐이...
스위치 오프.
2. 빈(Bean) 생성과 의존 관계 설정 □ 빈 생성 및 사용 ■ <bean>태그를 이용하여 생성할 빈 객체에 대한 정보 설정. ○ <bean> 태그 - 스프링 컨테이너가 관리할 빈 객체를 생성.
○ <bean> 태그 속성 - class : 생성할 빈 객체의 완전한 클래스 이름. - id : 스프링 컨테이너에서 생성된 객체를 구분하는데 사용되는 식별값. (name 속성을 사용해도 됨.) ■ 컨테이너로부터 빈 객체를 가져와 사용
- 식별값(id속성 또는 name 속성)을 getBean() 메서드에 전달해서 컨테이너로부터 객체를 가져올 수 있음. ■ 주의 사항 - <bean> 태그에 생성자와 관련된 정보(<constructor-arg>태그)를 명시하지 않았다면, 스프링은 파라미터가 없는 기본 생성자를 이용하여 객체를 생성. - 빈으로 사용할 클래스에 파라미터를 갖는 생성자를 정의했다면 기본 생성자도 함께 정의.
■ 빈 팩토리 메서드 ○ 생성자가 아닌 static 메서드를 이용하여 객체를 생성해야 하는 경우.
○ <bean> 태그에 factory-method 속성값으로 static 메서드를 지정 - 해당 메서드를 이용하여 빈을 생성하도록 설정.
- factory-method 속성을 지정하면 스프링 컨테이너는 생성자를 사용하지 않고 getInstance()메서드를 이용하여 ParserFactory 클래스의 객체를 구함. - WriteArticleServiceImpl 클래스는 ArticleDao 인터페이스에 의존.□ 의존 관계 설정 - 스프링 컨테이너에서 각 객체 간의 의존 관계도 XML 파일을 통해 명시 가능. ■ 생성자 방식 - 의존하는 객체를 생성자를 통해 전달 받음. ○ 의존 관계 ○ 생성자를 통해 의존하는 객체 전달 받기
● 특징 - 생성자를 통해서 의존하는 객체를 전달 받는 경우, <constructor-arg> 태그를 이용하여 의존하는 객체를 전달 할 수 있음. - 스프링은 <constructor-arg> 태그를 통해 전달된 값의 타입과 가장 근접한 파라미터를 갖는 생성자를 이용하여 객체를 생성. ● <constructor-arg> 태그를 이용한 생성자 방식의 설정
- <ref> 태그 대신에 <constructor-arg> 태그의 ref 속성을 사용하여 지정 가능.
- <ref> 태그 대신에 <value> 태그를 사용하여 값을 지정.
- 파라미터 개수 만큼 <constructor-arg> 태그 설정.
- 두 개의 생성자를 갖는 클래스 설정. ● 두 개의 생성자를 갖는 클래스
- Runnalbe 인터페이스를 상속받은 인터페이스.
- Runable 인터페이스를 구현한 클래스.
- executor2 빈을 생성할 때에는 Job을 전달받는 JobExecutor 생성자 사용. ○ 예제 - 두 개 이상의 생성자에서 기본 데이터 타입이나 래퍼 타입을 사용하여 생성하는 클래스 설정. ● 세 개의 생성자를 제공하는 클래스
- 스프링은 기본적으로 <value>에 전달된 값을 java.lang.String 타입으로 처리. 데이터 타입인 int인 생성자가 사용.
- <value> 태그뿐만 아니라 <constructor-arg> 태그에 type속성을 추가해도 동일한 동작을 함. ■ 프로퍼티 설정 방식 - setXXXX() 형태의 설정 메서드를 통해서 필요한 객체와 값을 전달 받음. (setXXXX() 형태의 메서드에서 프로퍼티의 이름은 XXXX가 됨.) ○ 설정 메서드를 통해 의존하는 객체 전달 받기
- 프로퍼티에 값을 전달. ● <property> 태그를 이용한 프로퍼티 값 설정
● 설정 메소드가 전달받는 값이 기본데이터 타입이나 String 타입일 경우 - <value> 태그를 사용하여 설정.
- XML 네임스페이스를 이용하면 <property> 태그를 사용하지 않고 좀 더 간단한 방법으로 프로퍼티의 값 설정 가능.
- 기본 데이터 타입 설정 : "p:프로퍼티이름" 속성을 사용하여 프로퍼티 값을 설정. - 빈 객체를 프로퍼티에 전달 : "p:프로퍼티이름-ref" 속성을 사용. ■ 임의 빈 객체 전달 - 식별 값을 갖지 않는 빈 객체를 생성해서 전달 가능. - <constructor-arg> 태그나 <property> 태그에 <bean> 태그를 중첩해서 사용.
□ 컬렉션 타입 프로퍼티 설정 ■ 컬렉션 타입을 입력받기 위한 스프링 태그 ■ List 타입과 배열 ○ 특징 - java.util.List 타입의 프로퍼티나 생성자 인자에 값 목록을 전달. - <list> 태그 사용 ○ 설정 방법
○ <list> 태그 - List에 저장된 객체 목록을 <ref> 태그를 이용하여 전달 받음. - <bean> 태그를 이용하여 식별 값을 갖지 않는 임의 객체를 List에 전달 가능. ○ List에 저장되는 값이 래퍼 타입이거나 String 타입일 경우 - <value> 태그를 사용하여 값 전달. - <list> 태그의 value-type 속성을 이용하여 List에 저장될 값들의 타입 명시 가능. - <value> 태그에 type 속성을 이용해도 List에 저장될 값들의 타입 명시 가능.
○ Generic 을 이용할 경우 - <list>나 <value>태그에 값의 타입을 명시하지 않아도 알맞게 타입을 변환.
○ List에 저장될 값을 표현하기 위해 사용 가능한 태그 - <ref> : 다른 스프링 빈 객체를 값으로 사용. - <bean> : 임의 빈 객체를 생성해서 값으로 사용. - <value> : 래퍼 타입이나 String을 값으로 사용. - <list>, <map>, <props>, <set> : 컬렉션 객체를 값으로 사용. - <null> : null 값을 값으로 사용. ○ 배열 - <list> 태그는 배열을 설정할 때도 사용.
- <list> 프로퍼티를 이용해서 값 전달. ■ Map 타입 ○ 특징 - java.util.Map 타입의 프로퍼티를 설정. - <map> 태그 사용. ○ 설정 방법
○ <entry> 태그 - 한 개의 <entry> 태그는 Map에 저장될 한 개의 <키, 값>을 표현. - 두 개의 자식 노드를 가지며, 각각 키와 값을 의미.
● <키태그>와 <값태그>에 지정할 수 있는 태그 - <ref> : 다른 스프링 빈 객체를 키로 사용. - <bean> : 임의 빈 객체를 생성해서 키로 사용. - <value> : 래퍼 타입이나 String을 키로 사용. - <list>, <map>, <props>, <set> : 컬렉션 객체를 키로 사용. - <null> : null 값을 키로 사용. ○ 예제
○ <entry> 태그의 속성을 이용하여 표현 - key, key-ref, value, value-ref 속성을 이용하여 <키, 값> 쌍을 좀 더 간단히 표현.
- 래퍼 타입이나 String 타입을 키나 값에 할당할 때에는 key 속성과 value 속성을 사용. - 빈 객체를 참조할 때에는 key-ref나 value-ref를 사용하여 설정. ○ 제러닉을 사용하지 않은 상태에서의 래퍼 타입의 키나 값 설정 - key-type 속성과 value-ref 속성을 이용하여 키와 값의 타입을 지정.
■ Properties 타입 ○ 특징 - java.util.Properties 타입의 프로퍼티 설정. (Properties 클래스는 환경변수나 설정 정보와 같이 상황에 따라 변경 되는 값을 저장하기 위한 용도로 사용.) - <props> 태그 이용. ○ 설정 방법
- 프로퍼티 이름 : "server"와 "connectionTimeout" - 프로퍼티의 값 : "192.168.1.100"과 ."5000" ○ <prop> 태그 - 한 개의 프로퍼티를 표현. - 프로퍼티의 이름은 key 속성을이용하여 입력. - 프로퍼티의 값은 <prop>태그의 몸체 내용을 이용하여 입력. - 한 개의 <prop> 태그는 Properties 태그에 한 개의 프로퍼티로 저장. (Properties.getProperty(String name)메서드를 이용하여 프로퍼티 값을 사용.)
■ Set 타입 ○ 특징 - java.util.Set 타입의 프로퍼티를 설정. - <set>태그를 이용. ○ 설정방법
○ <set> 태그 - 집합에 저장될 값을 <value> 태그나 <ref> 등의 태그를 이용하여 표시. - 래퍼 타입인 경우 <list>나 <map>의 경우처럼 value-type 속성을 이용하여 저장될 값의 타입을 명시. (<value>태그의 type 속성도 이용 가능.) ● 값을 지정할 수 있는 태그 - <ref> : 다른 스프링 빈 객체를 값으로 사용. - <bean> : 임의 빈 객체를 생성해서 값으로 사용. - <value> : 래퍼 타입이나 String을 값으로 사용. - <list>, <map>, <props>, <set> : 컬렉션 객체를 값으로 사용. - <null> : null 값을 값으로 사용. □ 의존 관계 자동 설정 ■ 빈 객체 간의 의존 관계 설정 - <property> 태그를 이용하여 설정.
- writeArticleService 빈 객체에서 articleDao 객체로의 하나의 의존 관계만을 포함. ■ 의존관계 자동 설정 - 의존하는 빈 객체의 타입이나 이름을 이용하여 의존 객체를 자동으로 설정할 수 있는 기능 제공. (설정 파일의 크기를 줄일 수 있음.) ○ 특정 방식을 이용하여 의존 객체 설정- 자동 설정과 관련하여 별도의 설정을 하지 않으면 자동 설정을 사용하지 않게 됨. ○ 자동설정 방식 - <bean> 태그에 autowire 속성을 값을 알맞게 지정.
- 기본 값 : default (default-autowire 속성의 값을 사용.) ○ 설정 파일에 포함된 모든 빈 객체에 대해서 특정 방식의 자동 설정 적용 - <beans> 태그의 default-autowire 속성의 값에 설정 방식을 지정.
● default-autowire 속성 - 기본 값 : no (자동 설정 하지 않음.) ■ 프로퍼티 이름을 이용한 의존 관계 자동 설정 ○ 특징 - byName 방식. - 프로퍼티 이름과 동일한 이름을 갖는 빈 객체를 프로퍼티 값으로 설정. ○ 설정 방법
- WriteArticleServiceImpl 클래스가 이름이 "articleDao"인 프로퍼티를 갖고 있다면, 이름이 "articleDao"인 빈 객체가 프로퍼티의 값으로 전달됨. ○ 단점 - 코드를 리팩토링해서 프로퍼티의 이름을 변경하는 경우 기존에 올바르게 동작하던 설정 파일이 올바르게 동작하지 않을 수도 있음. ■ 프로퍼티 타입을 이용한 의존 관계 자동 설정 ○ 특징 - byType 방식. - 프로퍼티의 타입과 동일한 타입을 갖는 빈 객체를 프로퍼티 값으로 설정. ○ 설정 방법
○ 단점 - 프로퍼티 타입과 동일한 타입의 빈 객체를 오직 1개만 설정 가능. (동일한 타입의 빈 객체가 두 개 이상 존재하게 되면 스프링은 어떤 빈 객체를 사용해야 할 지 알 수 없기 때문에 예외 발생.) ■ 생성자 파라미터 타입을 이용한 의존 관계 자동 설정 ○ 특징 - constructor 방식. - byType 방식처럼 타입을 이용하여 값을 전달. (차이점 : 프로퍼티가 아닌 생성자의 파라미터 타입 사용.) ○ 설정 방법
- WriteArticleServiceImpl(ArticleDao articleDao) 생성자의 첫 번째 파라미터에 ArticleDao 타입인 mysqlArticleDao 빈 객체가 전달됨.
- constructor 방식과 byType 방식을 사용하므로, 동일한 타입의 빈 객체를 2개 이상 정의 할 수 없음. ■ 자동 설정과 직접 설정의 혼합 ○ 특징 - 자동 설정과 함께 <property> 태그를 이용하여 해당 프로퍼티의 값을 직접 설정. ○ 설정 방법
- <null> 태그를 이용하여 프로퍼티의 값을 null로 설정.
설정.
■ 부모 빈으로부터 설정 정보 상속
○ commonMonitor 빈 생성.
[출처] 2. 스프링 DI (빈 생성과 의존 관계 설정)|작성자 외계인셩 |
poi cell Number 포맷 문자로 읽기 (0) | 2016.11.04 |
---|---|
에러코드 정리 (0) | 2016.05.25 |
에자일 방법론 (0) | 2016.03.29 |
java.lang.UnsupportedClassVersionError (0) | 2016.03.28 |
java 윤년, 평년 구분하기 (0) | 2016.01.18 |
에자일 방법론은 다음의 4가지 선언에서 시작되었다고 한다.
1. 프로세스나 툴 보다는 멤버간의 교류를 소중히 여길 것.
2. 포괄적인 문서에 힘을 쏟기 보다는 동작하는 소프트웨어의 개발에 힘을 기울일 것.
3. 계약의 협상보다는 고객과의 협력을 중시할 것.
4. 계획에 따르기 보다는 변화에 유연하게 대응할 것.
에러코드 정리 (0) | 2016.05.25 |
---|---|
스프링 DI (0) | 2016.03.29 |
java.lang.UnsupportedClassVersionError (0) | 2016.03.28 |
java 윤년, 평년 구분하기 (0) | 2016.01.18 |
마이바티스 메뉴얼 (0) | 2015.08.26 |
java.lang.UnsupportedClassVersionError
(Unsupported major.minor version 49.0) <- 이거 중요하다. 잘 외워두자
이 에러는 자바의 컴파일 버전이 충돌이 나서이다.
하위버전의 클래스파일을 상위버전이 읽어들일때는 상관없지만
상위버전의 클래스파일을 하위버전이 읽어올때는 위와 같은 에러를 낸다
< 에러 상세코드 >
version 50.0 컴파일 버전 : 1.6
version 49.0 컴파일 버전 : 1.5
version 48.0 컴파일 버전 : 1.4
해결책>>
내텀퓨터 ->속성 -> 고급-> 환경변수에서 자바의 버전을 알맞게 셋팅한다.
즉... 상위 버전에서 컴파일된 파일들은 모두 자신이 현재 쓸려고 하는 하위버전대로 다시 컴파일 하여야 한다.
진짜 해결>>
컴파일시 발생하는 Unsupported major.minor version 49.0 에러 원인
Unsupported major.minor version 49.0 에러 딱보니 버전문제다.
JRE 라이브러리 버젼을 통일시켜 주었는데도 안된다.
뭐가 문제냐!! 바로 컴파일시 JDK버젼이 문제였다.
프로젝트 프로퍼티에서 Java Compiler탭에서 Compiler compliance level을 설정을 변경해주자
이상 끝~
컴파일러의 jre 버전이 5.0 인데 웹서버 (톰켓)의 jre 버전이 1.4이거나 낮은 버전일 경우 다음과 같은 에러가 발생한다
참조] http://mars0717.egloos.com/1061030
스프링 DI (0) | 2016.03.29 |
---|---|
에자일 방법론 (0) | 2016.03.29 |
java 윤년, 평년 구분하기 (0) | 2016.01.18 |
마이바티스 메뉴얼 (0) | 2015.08.26 |
spring unchecked warning 발생 시 대처 법 (0) | 2015.08.05 |
그리운 사람이 더욱 그리운 사람이 되기 전에
더 많이 사랑하세요.
가슴에 묻힐 땐 기다려도 오지 않는 사람이 되고 난 후,
그 후엔 꿈속에나 만나는 슬픈 사랑이 됩니다.
그 사람이 그립습니다.
털털하게 사람의 마음에 향기를 주던 사람,
비처럼 땅에 내려 앉아 연두빛 새싹을 피어나게 하고
연분홍빛 꽃을 피우게 한 그 사람.
더 그리워지기 전에 더 많이 사랑하세요.
꿈속에나 만날땐 그 온정 만져지지 않을 테니,
손에 따스한 핏기가 서려 있을 때 손 한번 잡아주세요.
오년이 십년이 되고
내 자신이 그리운 사람이 되면
그 그리운 사람을 만날 수 있으려나,
하늘에서 무심한 듯 소낙비 내립니다.