캡슐화

-은닉성

 

상속(has A / Is a)

has a : 분리형, 일체형

is a single / multi (x) : extends , implements

 

추상화

-공통분모 : abstract 클래스, abstract 메소드

 

다형성

-절차의 일부분을 분리할 수 있다 - 인터페이스가 필요하다.

-절차의 분리와 도킹

 

자바 인터페이스 : 객체와 객체를 이어주는 접점

인터페이스 : 사물 또는 공간을 이어주는 접점

인터페이스를 통해서 정의하고 구현하고 사용하는 절차가 접함이되면 ?

다형성이 발생

 

일부 절차가 인터페이스로 정의된다 ?

A클래스가 인터페이스를 정의하였다.

 

인터페이스를 구현하는 방법 4가지

1. 외부클래스로 구현 : public class YBMBanner implements Banner

2. 내부클래스로 구현 : public class YBMExamConsole extends ExamConsole implements Banner

3. 메소드내의 중첩클래스로 구현 : 생성자 public YBMExamConsole(){ YBMExamConsole.XXX x = this.new XXX(); }

                                            YBMExamConsole 클래스내에 class XXX implements Banner

4. 익명클래스로 구현 : Banner banner = new Banner() { 구현 } 

5. 람다식이용한 구현

 

중첩클래스의 용도가 꼭 인터페이스용은 아니다.

인터페이스를 객체화할 수없다.


인터페이스의 메소드를 구현할때 부모의 메소드명과 동일하다면 ? 

부모것을 재정의한것처럼되어버림

좌 : 재사용하는 자식 / 우: 부모클래스

부모의 메소드를 오버라이드, 인터페이스를 구현하는것

부모가 이미 print()함수를 가지고있다. 인터페이스가 구현하려는것도 print()다.

->부모것을 재정의한것처럼되어버림

 

인터페이스의 구현은 다른클래스에서해도되지만

부모클래스의 메서드를 오버라이드하는일이 발생한다.

또 클래스를 만든다 ? 이게 부품이라고 할 수있나 ? (너무작은부품들로 개체수가 느는것)

->바람직하지않음

 

클래스안에 클래스가 정의될수있다. (인터페이스구현하기위한 울타리) 메소드충돌

 

좌 : outer / 우 : inner

 

프린트호출할때 a는 두가지 this가 전달된다 

1. 울타리밖에있는 객체의 인스턴스 (YBMExamConsole)

2. XXX의 인스턴스

 

중첩된 클래스의 객체화

import부분에 클래스명 

또는 XXX(inner 클래스)앞에 Outer클래스를 써준다.

클래스안에있는 클래스사용시 import를 하거나 직접 객체앞에 써줘야한다.

 

inner클래스의 객체는 outer객체를 통해 만들어진다. 

new XXX()객체는 outer객체를 통해 만들어져야한다. 

outer를 통해서 만들어져야한다.

outer객체가 갖고있는 new라는 연산자사용

 

 

 

main()이아니라 YBMExamConsole을 작성하는 사람이  XXX의 객체를 만든다.  

초기화작업은 YBMConsole만든사람이 하는게낫다.

XXX객체생성을 YBMExamConsole생성자에넣는다. 

XXX객체생성을 YBMExamConsole생성자에넣는다. 

인터페이스를 메소드내 중첩클래스로 구현 

new연산자앞에 this.객체가있었다
생성자내에 중첩클래스 : 메소드내 중첩클래스 

중첩클래스의 this :두개의 this가 올 수있다. 

outer클래스의 a가 선언되고 inner클래스의 a가 선언되었을때

우선순위가 적용된다. 자기것 (inner)의 a가 호출된다.

outer의 a를 출력하고자 한다면 ?

그냥this쓰면 inner의 this

 

Outer클래스명을  쓰고 this를 쓰면 내부클래스의 a가 출력된다. 

 

 

setBanner(x)에 넣기위해서 생긴 익명클래스

좌: 내부클래스의 이름을 없애고 우: 익명클래스로 바꿈 

 

 

 

'2021 Newlecture > JAVA' 카테고리의 다른 글

String , StringBuffer, StringBuilder 차이점  (0) 2021.08.20
자바 컬렉션과 제네릭 강의  (0) 2021.04.25
자바 총 정리  (1) 2021.04.13
Inner class / Anonymous class  (0) 2021.04.12
(추가정리) 추상클래스 와 인터페이스  (0) 2021.04.11
(추가정리) 상속  (0) 2021.04.10
(추가정리)this키워드  (0) 2021.04.10
(추가정리) 패키지와 static  (0) 2021.04.10

추상클래스

클래스의 공통된 부분을 뽑아서 별도의 클래스(추상클래스)로 만들어 놓고, 이것을 상속해서 사용한다.

추상클래스 구현

클래스 상속과 마찬가지로 extends 키워드를 이용해서 상속하고 abstract(추상)메서드를 구현한다.

Bank추상클래스

인터페이스 vs 추상클래스

인터페이스란?

클래스와 달리 객체를 생성할 수는 없으며, 클래스에서 구현해야 하는 작업명세서이다.

인터페이스를 사용하는 이유

가장 큰 이유는 객체가 다양한 자료형(타입)을 가질 수 있기 때문이다.

인터페이스 구현

class 대신 interface 키워드를 사용하며, extend 대신 implements 키워드를 이용한다.

interface를 이용하면 객체가 다양한 자료형타입을 가질 수 있다.

'2021 Newlecture > JAVA' 카테고리의 다른 글

자바 컬렉션과 제네릭 강의  (0) 2021.04.25
자바 총 정리  (1) 2021.04.13
Inner class / Anonymous class  (0) 2021.04.12
인터페이스 구현  (0) 2021.04.12
(추가정리) 상속  (0) 2021.04.10
(추가정리)this키워드  (0) 2021.04.10
(추가정리) 패키지와 static  (0) 2021.04.10
인터페이스  (0) 2021.04.08

데이터를 주고받는 주체

데이터를 송수신하는 통신의 주체는 애플리케이션

애플리케이션간의 통신은 양방향이다.

애플리케이션간의 통신 방식은 클라이언트 서버 애플리케이션 과 피어두피어 애플리케이션으로 분류된다

 

통신에서 이용하는 언어

통신하기 위한 데이터 형식 등의 규칠을 프로토콜이라고 부른다

복수의 프로토콜을 조합한 네트워크 아키덱처에 기반하여 통신한다

현재는 네트워크 아키덱처로서 TCP / IP를 이용한다

 

네트워크의 구성

PC나 서버, 네트워크 기기에는 네트워크에 접속하기 위한 인터페이스가 갖추어져 있다.

인터페이스끼리 전송매체로 연결하고 링크를 구성해서 네트워크를 만든다.

인터페이스는 0,1 의 디지털 데이터와 물리적인 신호의 경계다.

 

 


프로토콜 : 통신하기위한 규칙

헤더 : 데이터를 보낼때 필요한 정보를 데이터에 추가한 정보. 저장되거나 전송되는 데이터의 맨앞에 위치하는 추가적인 정보데이터. 데이터의 내용이나 성격을 식별 또는 제어하는데 사용  

캡슐화 : 데이터를 상대방에게 보낼때 각 계층에서 헤더를 포함하여 나가는것 <->역캡슐화

 

'* > What I did today' 카테고리의 다른 글

JOIN  (0) 2021.08.21
Process vs Thread  (0) 2021.08.20
dto와 entity를 구분해서 구현한 이유  (0) 2021.08.20
Web Server VS WAS  (0) 2021.08.16
스프링 핵심 원리 이해1 - 예제 만들기  (0) 2021.08.06
캡슐화/추상화/다형성  (0) 2021.08.03
DNS  (0) 2021.05.02
비전공자를 위한 이해할 수 있는 IT지식 (정리)  (0) 2021.04.13

상속이란?

부모 클래스를 상속받은 자식 클래스는 부모 클래스의 속성과 기능도 이용할 수 있다.

상속의 필요성

기존의 검증된 class를 이용해서 빠르고 쉽게 새로운 class를 만들 수 있다.

상속 구현

extend 키워드를 이용해서 상속을 구현한다.

최상위->상위클래스가 먼저 생성된다.->자식클래스 생성

자바는 단일상속만 지원한다

(다른언어:extends Class1, Class2,...)

 

자식클래스 객체를 만들면 부모생성자가 먼저실행된 후 자식생성자가 실행된다. 

부모 클래스의 private 접근자

자식 클래스는 부모 클래스의 모든 자원을 사용할 수 있지만, private 접근자의 속성과 메서드는 사용할 수 없다.

 

메서드 오버라이드

부모 클래스의 기능을 자식 클래스에서 재정의 해서 사용한다.

자료형(타입)

기본자료형 처럼 클래스도 자료형이다.

모든 클래스의 최상위 클래스는 Object 클래스이다.

상위 클래스를 호출할 때 super 키워드를 이용한다.

'2021 Newlecture > JAVA' 카테고리의 다른 글

자바 총 정리  (1) 2021.04.13
Inner class / Anonymous class  (0) 2021.04.12
인터페이스 구현  (0) 2021.04.12
(추가정리) 추상클래스 와 인터페이스  (0) 2021.04.11
(추가정리)this키워드  (0) 2021.04.10
(추가정리) 패키지와 static  (0) 2021.04.10
인터페이스  (0) 2021.04.08
protected method() / 자식에게 부모 객체넘겨주기  (0) 2021.04.07

디폴트 생성자

객체가 생성될 때 가장 먼저 호출되는 생성자로, 만약 개발자가 명시하지 않아도 컴파일 시점에 자동 생성된다.

디폴트 생성자 외에 특정 목적에 의해서 개발자가 만든 생성자로, 매개변수에 차이가 있다.

this 현재객체를 의미

 

다른패키지에있는 클래스를쓰려면 패키지풀네임.클래스이름으로 import해야한다

또는 패키지풀네임을 적을 수도있다
dailyJournal안에있는 모든클래스

static변수

동일한클래스에서 만들어진객체는 메모리상에 별도로존재 . 아주다른 별개 객체

static키워드가 붙은변수는 서로 데이터를공유

 

 

배열에서 식별자 : 인덱스

자동화된 인덱스 순환구조

 

오브젝트의 식별자 : 키

obj[속성명]

for in 문으로 객체를 갖는 속성을 순환할 수있다.

 

항상 선언이 먼저 인식되고(stack에 올라감) 연산절차가 진행된다. 

 

인터프리터 : 소스코드바로실행, 버추얼머신

컴파일러 : 소스코드번역해서 ->번역된결과물실행

모든객체에 속성을 마음대로 붙일 수있다.

 

앞에 아무것도 안붙이면 전역변수

var를 붙이면 지역변수가 되는데, 함수를 선언하고 그안에서 var로 선언해야 지역변수가 된다. 

console.log(a);

var a = 1;하면 

undefined가 나온다. 오류가 아니다.

선언이 되지않은걸 실행하면 오류가 날것같은데.. 오류가 아니고 undefined가 나온다.

  • 선언한것은 코드가실행 되기전에 미리 stack에 올라간다.
  • console.log(a)이후에 var a를 선언했어도 정의/선언된걸 먼저 찾기 때문이다. 이 후 연산이 진행된다.
  • var a는 실행문장이 아니다.

 

 

 

 

var x 가 스택에 올라간다. 

선언이 뒤에가있어도 

코드실행시 선언된것이 먼저 캐치되서 준비되고, 연산이 실행된다.

 

window.가 생략된것 

window객체의 변수 (this.처럼생략)

윈도우에 a를 추가한것으로 이해한것

  • <script>는 전역영역
  • window라는 전역객체가있다.
  • 변수선언하지않고 a = 1;라고 쓰게되면, (window.)a = 1; 전역객체에다가 a속성을 정의 한것이다.
  • alert도 window객체의 함수다. (window.)alert(a); 
  • 기본적으로 window객체를 기본적으로 활용하는 영역이기때문에 생략된다 

window. 이 생략된것

 

자바와 비슷하다.

this에 a가있어.

지역변수에 a가있나 봤더니 a가 없어.  - > this에 a가 있나 ? -> int a 있다 -> f1()에서 대입하고있는 3은 this의 a속성에 대입된다.

 

var를 붙이는것 : 지역변수선언

진짜지역을 갖고있는 블록이 존재하면 거기서 var를 붙이면 그 지역에서만 사용할 수 있는 변수가 만들어진다.

{ }를 안하면 선언헀던 안했던 전역변수가 된다.

 

오류가 안난다...지역화안되나요 ?

자바스크립트에서 지역화는 없다.

함수지역만 가능하다. es 5버전

함수내에서 var를 붙이면 의미가 달라진다 

오류가 나지않는다.

 

Pseudo-classes

 

테이블구분 이미지 넣기

첫번째애한테만 적용제외하기

번호앞의 이미지가 가라졌다.

현재페이지정보 글자 오른쪽정렬

 

위아래 같은것

배열표현

데이터를 구분하기 위한 표현방법

오브젝트 notice의 title키의 값 hello출력
' ' 문자열이다. 오브젝트객체를 표현하는 표기법으로 쓰여있지만 현재문자열이다.

담겨진건 객체가 아니라 문자열이다. undefined로나온다

 

문자열로 넘겨진것들을 객체로 받으려면 ?

 

"x=3;"을 출력하면 

undefiend 

eval()은 문자열을 코드로 인식하게 하는 함수

자바스크립트라는 코드를 실행해주는코드

eval은 코드를 실행해준다.실행되는 코드가 한문장으로 완벽해야한다

 

위에는 완벽한 문자열이아니라서 오류

인터넷에서 가져온 문자열이 [2,3,4,5]였다면 ( )으로 감싸줘야한다

( )으로 감싼것                                                              ( )을 각각 문자열더해줌

( )으로 감싼 뒤 배열객체 data에 담긴다.

4가 출력된다.

문자앞뒤에 ()감싸면 

자료제공자가  ( )붙여서 줄수없을수 있으니

받은데이터에 ( )를 덧씌우는 json = "(" + json + ")"를 거치고 eval()해서 객체화

 

""안써도 id, title을 키값으로 안다
일반적이지않은 키값은 " "쓰고, 호출할때는 [" "] 묶는다

JSON Parse 

JSON형태라면 json을 객체로 인식해서 파싱해준다.

parse 메소드는 string 객체를 json 객체로 변환

키의 표기는 따옴표

키값을 완벽히 문자열로표현

제이슨파스쓸때는 키 를 더블따옴표로" "  써야한다

각 키값을 "  "따옴표 (문자열형태)을 써야한다 aaa출력 

반대로 JSON문자열로 바꿔야한다면 ?

JSON.stringify

json 객체를 String 객체로 변환시켜 줍니다.

 

eval("var ar = " + data + ";" );

data의 문자열을 ar 배열에 담는다

배열0번째의 co값을 출력한다. 0.6

== 값만비교 (.equals())

===참조비교  

for in

키를 뽑아내주는 제어구조이다

그 안에있는것들을 하나씩꺼내서 전체를 순회하는데 도움을준다

ar의 데이터를 식별할때 유일한 식별자는 순서다

 

전체다 순회할때

ojt의 식별자는 key다 kor, eng, math (키는순서가없음)

오브젝트를넣으면 오브젝트의 키를 뽑아낸다

키값을 담을수 있는 변수가 k인것

 

오브젝트는 확장이가능하다.

 

영역을 넘는 콘텐트 처리

높이가 계속커진다.

층을만들어낸다 -> 막는속성

 

  white-spacenowrap;

제목이 층을 만들어내지않게 하기

 overflowhidden;

넘치는 글자 가리기

   

text-overflowellipsis 

오버플로우된 글자는 ...점으로 생략된다

테이블의 헤더넣기

 

테이블의 제목열만 왼쪽정렬하기

 

테이블의 헤더와 바디구분

tbody를 넣지않으면 html이 알아서 table과 tr사이에 tbody를 넣어준다

thead와 tbody를 넣어 구분한다.

요청했던 사용자의 브라우저에 문자열을 돌려주자 

HttpServletRequest request : 사용자가 요청할때 우리에게 입력값을 줄 수있다.

HttpServletResponse response : 우리가 사용자에게 입력할때 사용 할 수 있는 도구들을 담아두고있다.

자바 +웹출력도구 ->웹입출력가능

 

 

요청한 사용자에게 웹을통해 출력이된다.

 

콘솔출력했던것들이 사용자에게출력가능 , 웹을 이용해 출력

10번 반복 출력

 

 


사용자가 요구하는 만큼 반복해보자 

주소에 물음표뒤에 &구분자가있다. 키와 값을 쌍으로하는 값이 나열되어있다.

사용자가 부가적인 정보를 질의하는것과 같다. 

햄버거가게 : 치즈버거+양파제외+ ~~

커피숍 : 아메리카노 + 샷추가  등등

가게와 손님이 약속이된 한도내에서 질의요청 - > 제공

 

 

사용자가 c라는 키워드로 값을 전달

?c=5 5번요청

 

 

request.getParameter("c") //약속된키워드 c

약속된 키워드를 읽어봤더니 null아니다 -> 사용자 값을 이용한다 count = Integer.parseInt(c);   

약속된 키워드를 읽어봤더니 null이다 -> 기본값 int count = 10;

 

 

사용자가 ? c=20을 입력하면 20번반복되어 출력된다.

hello를 달라고하면서 추가옵션 c=20을 요청한것

 

 

검색폼이 물음표뒤의 값을 만들어줄것

 

Get Request -> QueryString(폼태그를이용하게될것)

(톰캣이 WAS서버를 탑재)

어플리케이션을 실행해주는것을 통해 실행하면 실행되는 시작은 원격에 있는 브라우저가 요청하므로써 실행된다.

문자열출력은 PrintWriter를 이용할것 

PrintWriter out = response.getWriter();


전달하고자하는 데이터형태

브라우저가 받는건 데이터를 직접받지않고 웹문서를받는다.

 

문서를 출력 : 브라우저(웹문서 뷰어)

데이터 출력 : 데이터요청하는게 자바스크립트

1.브라우저에서 스크립트가 동작하지않는 환경이라면 문서출력

2. 스크립트가 동작하는 환경이라면 문서대신 데이터를 제공하므로써 데이터를 가지고 스크립트가 문서를만들게한다. 

 

 

 


만든 calc.html파일의 인코딩이 EUC-KR이다.

 

알트 엔터->속성 조회  

 

calc.html파일을 지우고 UTF-8을 적용해보자

window -> preference -> web -> HTML , CSS, JSP UTF-8선택후 Apply적용

 

UTF-8적용된모습

 


서버실행시 다른프로세스에서 이미 실행중이라는 오류 

1. 작업관리자 열기 -> 세부정보 -> java검색

2. 콘솔창 -> netstat -ao -> 8080찾기 -> 작업관리자에서 26872쓰는 프로그램찾기 

3. zoom이 8080을 쓰고있다..일단 포트번호만바꿔서사용해보기 

 

 

 

ctrl + c + ipconfig 

 

 

인터페이스

인터페이스란 두 사물 또는 세계가 간접적으로 만날 수 있게해주는 도구 또는 접점

자바 인터페이스란 객체 간의 조립을 간접적으로 조립하게 Has A 상속을 하게 해주는 접점 또는 도구

객체가 다른객체를 사용할때 이용하는 접점

코드의 일부분을 인터페이스로 약속해서 뺼 수 있다.

 

배너를 바꾸고싶다면                                                                                        (노란색이 인터페이스) 

옛날 배터리분리형 폰을 생각해보자. 

나중에 부품배터리 꽂아사용할 수있다. 

배터리를 사용하도록 약속되어있는 접근방법(노란색단자)을 제공해야한다.

다형성제공(배터디, 다양한제품을 쓸 수있다, 대용량 ,저용량, 기호나 사정,상황에맞게 배터리를 쓸수있다)

다양한 형태의 결합을 통해서 다양한 형태를 만들어 낼 수 있다.


public interface Banner

정의하는쪽 (제품쪽) : 코드의 일부분을 비워놓고 

구현하는쪽(부품) : 꽂아넣기 

 

인터페이스는 구현하는게 아니라 약속으로 정의한 00을 구현할 목록나열

약속으로 수반되어야할 목록을 무엇으로 구현해야하는지 정의

  • 멤버변수가없다. 
  • 다른 접근제한키워드를 쓰지않음 
  • Banner가 함수의 목록만 정의
  • 약속이기때문에 지금구현하지않는다.
  • 나중에 누군가 (YBMConsole)가 구현할 것 

public void setBanner(Banner banner)

기능을 분리하고자하는 쪽에서 기능을 정의해야한다.

정의한것을 다른쪽에서는 구현해야한다. 

interface Banner라는 약속으로 print와 printEnd를 구현한 객체를 private Banner banner;에 대입해주기 위한 도구

좌: 배터리를 꽂을수 있도록 변수를 두고/  가운데 : 배너 정의(배터리사용하는쪽) / 꽂아넣을수있도록 setter준비 

나중에 누군가가 banner 객체를 만들면 받아와야함 - 구현한쪽에서 꽂아줘야하니까 set메소드

(set()이없으면 내가 구현해야함)

내가만들지도,구현하지도않을것 - 들어올수있게하는방법이 set()메소드임.


인터페이스에 필요한 4가지 역할

  • 인터페이스는 약속을 정의하는것 (interface)
  • 마감(ExamConsole) : 인터페이스의 함수를 호출
  • 인터페이스구현(YBMBanner) : 
  • 구현한것을 꽂다 ybmConsole.setBanner(exam)

YBMBanner를 다른패키지에서 해야하지만 편의상 같은패키지에서 생성

ExamConsole에 ybmBanner를 꽂는것


YBMBanner가 Banner를 구현한다. 

배터리꽂아야 핸드폰을 킬 수 있다. (인터페이스를 구현하다)

인터페이스도 부모형이 참조가능하다.

 

 

약속을잡아놓고 구현하겠다 남이구현하게하겠다

1.자식만(onPrint) 2. 객체넘겨주는것 

꽂아주는작업 :인터페이스 

코드분리 ->누군가가가구현 -> 성질이 다양하게 바뀔 수있다. 

인터페이스는 다중상속을 대신한다

인터페이스를 구현하는 클래스가 반드시 새로운클래스일 필요없다.

 

자식만 구현하게하는것 / 객체로 누구나 구현할수있게하는것 

YBMExam이 Exam을 상속함 - onPrint는 자식이 구현하로했다.

약속해놓고 자식이 구현했다.

인터페이스로도 가능하다. 인터페이스목록으로하면 다른객체로서도 extends안해도 제공할 수있다. 

YBMExam이 인터페이스를 구현했다면 ? 

인터페이스는 클래스를 만드는게 중요한게아니라 구현했는지가 중요한것


클래스는 하나의 상속, 인터페이스 추가가능.

 


장소가 적합한가에대한 문제 

 

패키지명이달라져서 라이브러리명이달라짐

자카르타, 인코딩명이달라짐 (유티에프?)

톰캣이 제공하는 API가 달라졌을 경우, 그것을 활용하는 상위 라이브러리들이 달라지는데 시간이걸린다.

최신버전의 Spring이 과거버전의 서블릿을 쓰고있다. 최신버전의 서블릿을 쓰면 나중에 호환성 문제가 발생할 수있다.

 

어제 작업


서블릿이란 서버어플리케이션을 만든느것
기능벼로 코드가나뉘어짐
선택적실행

 

이클립스를 사용안하면 .. 
소스코드고치고
컴파일
클래스파일복사해서 클레스즈에 다시 붙여넣기
톰캣다시끄고시작하기
스타트업다시시작
서벗다시
주소입력다시


이클립스를 이용해서 톰캣을 실행->서블릿 실행

메모장보다 편리! 

web.xml이 서블릿을 실행하는 중요한 설정(설정내용이해)

브라우저를 띄우고 + 주소입력 해야했지만 web.xml를 선택하고 ctrl +f11누르면 쉽게 브라우저를  띄워서 그 주소까지 입력할 수있다.

 

 

Java EE

이클립스한테 톰캣실행해주도록 해야한다

서블릿코드는 톰캣에 의해 실행된다. 런타임환경을 구축해야한다. 

이클립스 다이나믹 웹 프로젝트 -> 타겟런타임 -> 뉴 런타임-> 내가 사용할 톰캣버전선택 -> 디렉토리선택 -> 9.0 홈디렉토리선택 bin이 보이는 폴더

 

WebContent 톰캣이 사용하는 기본폴더 -> index.html생성 -> "안녕하세요 " 입력

이클립스를 사용하지 않았을 경우, 톰캣을 직접 실행하고 브라우저를 열고, 로컬호스트번호로 요청해야한다.

WEB-INF에 기존 web.xml파일을 붙여넣기한다

 

웹출력

컨트롤 에프11(실행)

좌 : 이클립스내에있는 브라우저에 안녕하세요가 뜬다 / 로컬호스트주소를 브라우저창에뜨면 동일한 결과가 뜬다 
디폴트 브라우저 지정하기

패키지 추가 후 Nana.java파일 넣기 

실행시 런초록버튼 누르지말것 : Nana.java을 실행하는게 아니라 서버만 실행하는것 ->브라우저가 뜨지않는다

다시 런버튼을 누르면 서버만 계속 실행하는것 

splice(인덱스번호,삭제여부,추가할숫자)

중간에서 값을 삭제하거나 넣기 

 

nums.splice(2) 인덱스 2번부터 삭제해

nums.splice(2,2)

인덱스2번에서 2개를 삭제해.

nums.splice(2,0,3)

인덱스 2번에서 삭제를 안하고 3을 넣는다 (가운데가 0이면 삽입)

nums.splice(2,1,3)

인덱스 2번에서 삭제를하고 3을 넣는다. (가운데가 1이면 교체)

인덱스 2번에서 삭제안하고 3,4,5삽입

 


slice(시작,끝)

일부분을 추출함. 일부분 가져옴

익스클루시브 

(1,3) 1부터2까지 짤림


indexOf(3) //  해당숫자의 인덱스번호 

찾았으면 0이상

해당인덱스가 있으면 양수 , 없으면 음수


기본데이터형이 다 객체다.

객체지향언어이다.

인터프리터언어라 미리 정의하는것이 발달되어있지않다.

미리정의하는걸 안좋아한다.

 

미리정의하지않았어도 초기화하면서 동시에 정의가 된다. 먼저생성하고 정의함.


변수이름 대소문자 주의 

변수이름을 미리 정의하는게아니기 때문에 오타실수가 발생할수 있다

씨플플,씨샵,자바는 정의를 하고 객체를만든다 -정적인객체정의
자바스크립트는 객체만들고 정의 - 동적인객체정의
기본기를 잡기위해 자바스크립트를 배우고있다
가능하면 타임스크립트가 낫다
보안장치가있다.
앵귤러:기업형적합
자유도:리액트
모바일:뷰제이에스

속성명에 -(대시)를 쓸 수 없다.

속성사용할때는 문자열형태로 바꿀 수있다. 대시가 들어가던 안들어가던 사용가능 대괄호로 감싸기

문자열로표현한 속성은 대괄호 이용한다.

math는 유효한 속성명이라 두가지 방법 모두 가능하다.

"w-1" -대시가 들어가면 유효하지않은 속성명이므로 괄호를 써준다 

Object표기

위아래 같은것

 


JSON 생성방법

키와 값을 한번에 저장하는 컬렉션 등장 

객체를 직접만들 필요없다.

문자열과 문자를 같이 취급한다. (모두 문자열) " " ' ' 모두가능,

쌍따옴표,홑따옴표모두가능 하나 일단 쌍따옴표쓰는것으로 기억하기 

 

앞으로 배열생성할때 위와같이할것

객체를 제이슨표기법으로 만들기.

불,넘버,스트링,어레이빼고 모두 오브젝트임 (type)
불편

exam.a는 exam객체의 a 키를 부른것인데 exam객체중에 a 키는없다. 그래서 undefined

exam[a]는 exam객체의 키값을 a변수를 통해 "kor"속성명의 30값을 호출했다.

마진으로 다른애들이 못쓰고있음 파란색만큼만쓰고있음

width를 100%로 준다.


순번 : 컬럼순서가 바뀌거나 구조가바뀌면 번호를 다 바꿔줘야한다

이름 : 구조가바뀌어도 상관없음,

특화된 종속해서보다

스타일로서의 의미를 살리는 키워드를정하는게낫다

이름하고값이랑안맞아

이름을 값으로썻지만 나중에 값수정할 때 이름도수정해야해

border-collapsecollapse; 셀양쪽벽을 합치는 속성

테이블 셀사이의 보더를 없앴다. (마진이 아니다)

 

  table-layoutfixed;

fixed를 설정하지않았을 경우 컨텐츠가 길어지면 다음줄로 내려가고, 옆칸의 너비를 뺏어온다. 

우측 픽스드 적용 

 

 

객체지향프로그래밍

캡슐화 -> 엮어내기(has A) -> 상속(Is A) / 추상화 : ->다형성(인터페이스).

 

캡슐화 :기능들을 서비스캡슐화

Has a : 여러캡슐들을 엮어서조립

Is a : 남의것을 상속받아서 고쳐쓰기

추상화 : 내것을 남이 쓸수있도록 골격을 만들어냄, 자식이 구현

 

추상화 : 일부분만 고쳐쓸때 (부모의 super.input()을  호출)가 있다.

 

public class YBMExamConsole extends ExamConsole : Is a 상속

YBMExamConsole은 구현안해도 내가 만든것처럼 보여줄수 있다. 또는 부모것을 고쳐 쓸 수 있다.

 

객체화하지않게 하려면  abstract class 

자식이 꼭 구현하도록 강요하려면 abstract method()

 


호출 프로세스 (데이터가 확장되면 출력이 문제가 된다)

순서: console.print() -> 부모의 print() -> 부모 print()안의 onPrint() -> 오버라이딩된 onPrint() -> onPrint()호출된곳으로돌아감->print()호출된곳으로 돌아감

ExamConsole사용하다가 exam객체가 달라졌을 경우 ?

국영수가아닌 다른과목이 포함되어야할 경우?

 

기존의 Console을 확장해서 NewExam에 맞게 콘솔을 다시작성해야하는 상황이 발생한다.

→데이터확장 → 자식클래스도 확장 →다시다상속관계 =>해결 : 없음

 

  • 상속받아서 고치는데, 최대한 부모것을 재사용하도록 재사용범위를 넓혀야한다.
  • 부모가 확장을 염두해두지않고 만들어지면 재사용 불가능
  • 함수하나만들어서 자식에게만 노출되는 함수 (onPrint() )
  • onPrint()는 자식이 활용하기 위해 아무코드가 없다. 자식이 사용예정
  • Frame에서 setVisible()과 같다.

 

Exam형인 getExam을 NewlecExam으로 형변환 해준다.

 

getExam()을 사용하면 자료형이 Exam이다.

Exam객체는 getCom()을 가지고있지않으므로 형변환 해줘야한다. 

 

YBMExam exam = (YBMExam)getExam();

자식YBMExam은 getExam()(객체가져오는메소드)가 없고, 부모Exam은 setToeic()이없다.

부모에게있는 getExam()을 자식으로 형변환해서 가져온 후

자식YBMExam에있는 setToeic(), getToeic()을 호출한다.

 

각 참조변수자료형에 따라 어떤 메소드가 없는지 알 수있다.


protected void onPrint()

다음에 클래스를 재사용한다면 추상화 ->공통분모제공.최대한 공통분모를 재사용할수록해야한다

모든자식은 ExamConsole을 틀로쓰겠다는거잖아요

  • 자식입장에서 부모로 뒀을 경우 자식은 print()기능을 내가 구현하지않고 부모기능을쓰는게더좋겠죠.
  • 부모ExamConsole이 protected void onPrint()를 가지고있되, 구현은 자식이 해서
  • 자식객체가 바뀌었을경우 재정의해서 사용할 수있도록한다.

부모 ExamConsole클래스의 print()함수 내에 onPrint()넣음

자식이 재정의하면 재정의한 것을 호출하도록했다.

ybmConsole은 마치 자기가 구현한것처럼 실행한다. 


Protected Exam getExam() // 자식이 부모의 멤버변수에 접근하도록 getter메소드생성

자식 ybmConsole에서 Exam exam을 사용할 수없음

내가 가지고있는 데이터가 자식에게 사용할가능성이있다면 , 자식이 사용할수있게끔 기능을 제공해야겠죠

이게없으면 다른애들이 exam사용불가, 자식이만 사용하도록 protected

 

부모가갖고있는 private Exam exam은 자식도 못쓴다. 일정한서비스를통해 넘겨사용(getter)

exam이 다른자식들이 이용하게끔 최대한서비스를 해주는 것 ->추상화클래스역할

최대한쉽게 재사용할수있게해주고 데이터제공.

YBMExamConsole이 부모의 onPrint()를 재정의하기위해 부모객체가 필요하다.


오버라이드비교

onPrint()는 부모것 불러올게없다.

input()은 부모의 input()을 받은 후 진행해야한다. 즉 국,영,수를 받고 토익,a를 받도록 해야한다.(출력순서에따라)

 

package ex8.추상화.재사용;

import java.awt.Frame;

public class Program {

	public static void main(String[] args) {
		
		Exam exam = new YBMExam(1,1,1,1,1);
		
		YBMExamConsole ybmConsole = new YBMExamConsole();
		ybmConsole.setExam(exam);
		
		ybmConsole.input();
		ybmConsole.print();
   }
}
package ex8.추상화.재사용;

import java.util.Scanner;

public class ExamConsole {
	private Exam exam; //부품으로씀
	private PrintListener printListener;
	


	public PrintListener getPrintListener() {
		return printListener;
	}

	public ExamConsole() {

	}		

	public ExamConsole(Exam exam) {//오버로드생성자만들때 기본생성자만들어야함
		super();
		this.exam = exam;
	}

	public void setExam(Exam exam) {
		this.exam = exam;
	}
	
	public void setPrintListener(PrintListener printListener) {
		this.printListener = printListener;
	}
	
	protected Exam getExam() {
		return exam;
	}
	
	protected void onPrint() {
		
	}

	public void print() {
		System.out.println("-----------------------------");
		System.out.println("            성적 출력          ");
		System.out.println("-----------------------------");
		System.out.printf("kor:%d\n",exam.getKor());
		System.out.printf("eng:%d\n",exam.getEng());
		System.out.printf("math:%d\n",exam.getMath());
//		if(printListener != null)
//		printListener.onPrint();
		onPrint();//호출
		System.out.printf("total:%d\n",exam.total());
		System.out.printf("avg:%f\n",exam.avg());
		System.out.println("-----------------------------");
	}
	public void input() {
		Scanner scan = new Scanner(System.in);

		int kor;
		int eng;
		int math;
		System.out.print("kor:");
		kor = Integer.parseInt(scan.nextLine());
		System.out.print("eng:");
		eng = Integer.parseInt(scan.nextLine());
		System.out.print("math:");
		math = Integer.parseInt(scan.nextLine());
		
		exam.setKor(kor);
		exam.setEng(eng);
		exam.setMath(math);
		
	}

}
package ex8.추상화.재사용;

import java.util.Scanner;

public class YBMExamConsole extends ExamConsole{
	@Override
	protected void onPrint() {
		YBMExam exam = (YBMExam)getExam();
		System.out.printf("Toeic:%d\n",exam.getToeic());
		System.out.printf("aa::%d\n",exam.getAa());
	}

	@Override
	public void input() {
		super.input(); //국영수먼저 받고
		
		Scanner scan = new Scanner(System.in);
		
		int toeic;
		int aa;
		
		System.out.print("toeic:");
		toeic = Integer.parseInt(scan.nextLine());
		System.out.print("aa:");
		aa = Integer.parseInt(scan.nextLine());
		
		YBMExam exam = (YBMExam)getExam();//부모형은 자식형으로바로안
		exam.setToeic(toeic);
		exam.setToeic(aa);
		
	}
}

main에 padding 넣기 

패딩 : 상단, 오른쪽, 아래, 왼쪽

 

추상화 

1. 네모,세모,원,선을 만들다 보니 동일한 서비스들이 있다→ 동일한 기능을 일괄적으로 관리하기위해 추상화된 자료형 도형을 만들다.

2. 성적관리프로그램을 만들다 성적관리프로그램을 기반으로 만들어지는 제품을 위해 (다음에도 계속 사용하기위해) 공통분모화,추상화를하다.

 

DI (조립)

1. Constructor (생성자 종속성 조립)

2. Setter DI

 

  • 추상클래스는 추상메소드를 가지고 있다.
  • protected : 자식만 구현하도록 추상부모클래스에서 메소드에 제한거는것. 자식에게만 공
  •                같은 패키지 내에서, 그리고 다른 패키지의 자손 클래스에서 접근 가능
  • 부모의 private 멤버변수는 자식에게도 안보인다.
  • 클래스가 상속할 (자식을 낳을) 준비가 되지않았다면 , 재사용하기 불가능할 수 있다.
  • 객체가 YBMExam일때 출력도구도 달라져야한다. 
  • YBMExam전용 콘솔도구를 만들어야한다. 그때 ExamConsole이 재사용할 준비가 안되었다면 자식이 재사용할수 없게된다.

 


 

고쳐쓰는 방법 1 : 추상화 

사용자를 위한  껍데기부분을 만들때 상속이 많아지는 문제가 발생한다.

 

Exam class에 abstract를 지우고 시작.

출력을 위한 ExamConsole class{ }를 만들고 Exam class에 getter, setter를 추가한다.

 

Exam은 아직 객체를 갖지않았다.

객체를 갖는방벙 2가지

1. 객체를 자기가 만들거나

2. 남이 객체를 만들어서 넘겨주는것

 

ExamConsole console = new ExamConsole(exam);

ExamConsole 은 exam없이는 살 수없다.

exam을 생성할때 한번 꽂으면 더이상 다른 exam으로 대체할 수 없다.

Constructor DI : Dependency(종속성) Injection(주입) 생성자 종속성 주입

부품을 껴넣다.

AssoAssociation Has A 관계를 Injection하는것 => DI라고 한다.

ExamConsole은 exam을 분리형태로 부품으로 쓴다. 조립형

 

console.setExam(exam); 

언제든지 다른 객체로 바꿀 수 있다.

 

다양한 객체를 부품으로 사용한다.

Dependency: 재료가 되는 객체를 말한다. (has a)

exam은 ExamConsole이 자기 부품으로 쓰는것

Random은 함수를 일시적으로 쓰는것.

 

객체를 부품으로 사용한 예

필드를 사용하는 초기화하는 생성자

마우스오른쪽 -> source -> Generate constructor using fields

 

ExamConsole()와 ExamConsole(Exam exam) 생성자 공존 할 수없다.

Exam exam은 null이고

객체를 꽂을 수 있는 방법은 ExamConsole(Exam exam) 를 통해서만 가능하다.

ExamConsole()를 지우면 사용자는 ExamConsole(Exam exam)을 통해서만 객체를 생성할 수있다.

(기본생성자를 지우면 exam을 넣어야하는상황이된다)

 

ExamConsole()를 가능하게 한다면 

사용자가 기본생성자를 쓸 수있고 출력시 null값이 나온다.

생성할때 exam을 껴놓는 이유  ?  (exma)

 

exam을 생성자를 통해서만 만들게 했을까 ?

ExamConsole의 모든기능은 exam없이는 사용할 수없다.

 

e.g 스캐너도 기본생성자가없다. 입력스트림객체를 넣어줘야한다. 꽂지않으면 오류발생

객체를 넘겨줘야만 사용할 수 있다.

 

ExamConsole은 exam없이 독단적으로 사용가능?

사용할 수 없다.

ExamConsole은 반드시 생성하자 마자 exam을 갖고있어야 한다.

 

만약 누군가가 기본생성자를 호출한다면 내가 만들어주는것으로

public ExameConsole(){ exam = new Exam(); }

기본생성자를 저렇게만들면 밖에서 ()으로만으로도 할수있음

만들기나름,기획하기나름,선택가능

일체형
밖에서 호출할때

Setter를 통해 객체전달

Exam에 set함수 만들기

 public abstract int total();

total은 국,영,수뿐만 아니라 다른과목도 추가할 수 있어야한다.

국,영,수 합계를 자식이 직접계산할 필요는 없다. YBM ,다른고등학교에서는 과목이 달라질것이므로 고쳐쓸 수 있게한다.

상속을 통해 고쳐쓴다.

Exam클래스의 total 수정
NewExam에서 오버라이드한 모습

protected 

baseTotal()이 public이면 상속받는 자식에게만 구현하도록 만든 서비스이다.

자식에게만 보이게하는 키워드

내가 공통분모고 abstact, 자식만 구현하록하고싶을때 사용 

 

 

고쳐쓰는방법 2 : 인터페이스

 

객체를 YBMExam으로 바꿨는데, 여전히 국,영,수만 출력이된다.

지금 이그젬에만 특화되어있다

기존코드를 고치는 방법에 대해 ..

콘솔: 사용자에게 출력하는코드

exam은 자식을 계속 낳을 수 있다.

examConsole은 어떤객체(어떤자식)이꽂아질지모른다.

프린트가 부모영역으로만 한정된출력을가지고 있다.

달라져야한다 프린트의 기능이 객체종류에 따라 달라질 필요가 있다

 

저안에 들어갈 국영수외에 확장될부분을 너가 책임져줘.

단 구현해놔. 구현하지않으면 안하는거고~

자바는 함수만 꽂는건불가능 클래스안에 넣어야한닫.

onPrint를 구현해줘

누군가가 함수를 구현해서 객체를 넣어주기만 하면 ExamConsole을 재사용할 수있다.

public interface PrintListener 

함수에대한 약속만 나열한것 (구현x)

함수내용을 구현해서 꽂아넣었다면 

기본데이터객체 : boolean, number, string, undefined

 

배열 : 공간을 미리정하지 않아도 알아서 만들어준다. 공간을 줄였다 붙였다 할 수 있다.

 

  • var nums = new Array();
  • var nums = new Array(5); // 숫자가하나면 5개의 빈공간만들어짐(참조변수 5개만든것)
  • var nums = new Array(5,10,21); //  2개이상값은 배열의 초기화값으로됨. 3개짜리방에 1번째 5, 2번째 10, 3번째 21
  • var nums = new Array(5,10,21,"hello"); 다양한 형식넣을 수 있음
  • var nums = new Array(5,10,21,"hello", new Array(2,3,4));  alert(nums[4][1]) // 3

 

 

new Array(5) 공간생성, 비어있는 공간 5개 만들어짐

new Array(5,10); 배열의 초기화, 0번인덱스에 5, 1번인덱스에 10이 들어간다.

new Array(5, 10, "hello", new Array(2,3,4)); 배열을 담는 배열

배열속 배열의 1번 인덱스출력

자료구조

FIFO구조 : Queue 구조 선입선출

LIFO구조 : Stack 구조 후입선출

 

 

push(); 배열에 숫자 넣음 

pop(); 배열에서 마지막에넣은 숫자를 뺀다

shift() 앞에서부터 빼기 (큐)

+ Recent posts