Spring Security란? 

영어에서 번역됨-Spring Security는 엔터프라이즈 애플리케이션에 대한 인증, 권한 부여 및 기타 보안 기능을 제공하는 Java / Java EE 프레임 워크입니다. 위키백과(영어)

 

본인이 이해한 바로는.. 특정페이지에 대한 접근을 제어하거나 권한을 부여할 때 사용하거나,

DB의 저장되는 비밀번호를 암호화 해줄 때 사용한다. (그 외에도 많겠지만..)

 

 

우선 SpringBoot에서 Security를 사용하기 위해선.. (Spring Boot + gradle 기준)

build.gradle파일에서 dependencies 안에 추가해준다.

implementation 'org.springframework.boot:spring-boot-starter-security'

 

자 이제 Security의 설정을 하기 위해 Config파일을 생성한다. (클래스명은 본인 맘대로!)

@Configuration
public class SecurityConfig extends WebSecurityConfigurerAdapter {

    @Bean // 로그인 시 실행되는 메소드
    public AuthenticationProvider authenticationProvider(){return new LoginAuthenticationProvider();}

    @Bean // 로그인 성공 시 실행되는 메소드 
    public AuthenticationSuccessHandler successHandlerHandler() {
        return new LoginSuccessHandler();
    }

    @Bean // 로그인 실패 시 실행되는 메소드
    public AuthenticationFailureHandler failureHandlerHandler() {
        return new LoginFailureHandler();
    }

    @Bean // 패스워드 암호화 관련 메소드
    public PasswordEncoder passwordEncoder(){
        return new BCryptPasswordEncoder();
    }

    @Override
    public void configure(WebSecurity web) throws Exception {
        web.ignoring().antMatchers("/css/**", "/js/**");
    }

    @Override
    protected void configure(HttpSecurity http) throws Exception {
        http
                .csrf().disable()// 세션을 사용하지 않고 JWT 토큰을 활용하여 진행, csrf토큰검사를 비활성화
                .authorizeRequests() // 인증절차에 대한 설정을 진행
                .antMatchers("/", "/error/*", "/login", "/loginProc").permitAll() // 설정된 url은 인증되지 않더라도 누구든 접근 가능
                .anyRequest().authenticated()// 위 페이지 외 인증이 되어야 접근가능(ROLE에 상관없이)
                .and()
                .formLogin().loginPage("/login")  // 접근이 차단된 페이지 클릭시 이동할 url
                .loginProcessingUrl("/loginProc") // 로그인시 맵핑되는 url
                .usernameParameter("userId")      // view form 태그 내에 로그인 할 id 에 맵핑되는 name ( form 의 name )
                .passwordParameter("userPw")      // view form 태그 내에 로그인 할 password 에 맵핑되는 name ( form 의 name )
                .successHandler(successHandlerHandler()) // 로그인 성공시 실행되는 메소드
                .failureHandler(failureHandlerHandler()) // 로그인 실패시 실행되는 메소드
                .permitAll()
                .and()
                .logout() // 로그아웃 설정
                .logoutUrl("/logout") // 로그아웃시 맵핑되는 url
                .logoutSuccessUrl("/") // 로그아웃 성공시 리다이렉트 주소
                .invalidateHttpSession(true); // 세션 clear
    }
}

 설명을 해 보자면..

 

- @Configuration

환경 세팅(스프링의 기본 설정 정보들)을 돕는 어노테이션

클래스의 어노테이션을 @Configuration라고 선언하면 스프링에게 이 클래스는 환경 구성 파일이고 @Bean 어노테이션을 통하여 Bean임을 알려주게 된다.

 

- @Bean

개발자가 작성한 메서드의 return 되는 객체를 Bean으로 만드는 것이다.

 

그렇다면 Bean은 무엇일까?

Spring IoC 컨테이너가 관리하는 자바 객체를 빈(Bean)이라고 한다.

 

- WebSecurityConfigurerAdapter

스프링 시큐리티 설정에 관련된 클래스로 해당 클래스에 있는 메서드를 오버라이딩하여 시큐리티를 설정한다.

 

 

로그인에 관련된 메서드 : return되는 클래스들은 커스텀으로 구현하여야 한다.

@Bean
public AuthenticationProvider authenticationProvider(){return new LoginAuthenticationProvider();}

@Bean
public AuthenticationSuccessHandler successHandlerHandler() {
    return new LoginSuccessHandler();
}

@Bean
public AuthenticationFailureHandler failureHandlerHandler() {
    return new LoginFailureHandler();
}

 

패스워드 암호화와 관련된 메소드

@Bean
public PasswordEncoder passwordEncoder(){
    return new BCryptPasswordEncoder();
}

 

정적 페이지는 어디서든 접근 가능하도록 설정하는 메서드

@Override
public void configure(WebSecurity web) throws Exception {
    web.ignoring().antMatchers("/css/**", "/js/**");
}

 

접속 권한을 제어하는 메서드

@Override
protected void configure(HttpSecurity http) throws Exception {
    http
            .csrf().disable()// 세션을 사용하지 않고 JWT 토큰을 활용하여 진행, csrf토큰검사를 비활성화
            .authorizeRequests() // 인증절차에 대한 설정을 진행
            .antMatchers("/", "/error/*", "/login", "/loginProc").permitAll() // 설정된 url은 인증되지 않더라도 누구든 접근 가능
            .anyRequest().authenticated()// 위 페이지 외 인증이 되어야 접근가능(ROLE에 상관없이)
            .and()
            .formLogin().loginPage("/login")  // 접근이 차단된 페이지 클릭시 이동할 url
            .loginProcessingUrl("/loginProc") // 로그인시 맵핑되는 url
            .usernameParameter("userId")      // view form 태그 내에 로그인 할 id 에 맵핑되는 name ( form 의 name )
            .passwordParameter("userPw")      // view form 태그 내에 로그인 할 password 에 맵핑되는 name ( form 의 name )
            .successHandler(successHandlerHandler()) // 로그인 성공시 실행되는 메소드
            .failureHandler(failureHandlerHandler()) // 로그인 실패시 실행되는 메소드
            .permitAll()
            .and()
            .logout() // 로그아웃 설정
            .logoutUrl("/logout") // 로그아웃시 맵핑되는 url
            .logoutSuccessUrl("/") // 로그아웃 성공시 리다이렉트 주소
            .invalidateHttpSession(true); // 세션 clear
}

프로그래머스 : 보호소에서 중성화한 동물

 

  • 문제설명

ANIMAL_INS 테이블은 동물 보호소에 들어온 동물의 정보를 담은 테이블입니다. ANIMAL_INS 테이블 구조는 다음과 같으며, ANIMAL_ID, ANIMAL_TYPE, DATETIME, INTAKE_CONDITION, NAME, SEX_UPON_INTAKE는 각각 동물의 아이디, 생물 종, 보호 시작일, 보호 시작 시 상태, 이름, 성별 및 중성화 여부를 나타냅니다.

 

ANIMAL_OUTS 테이블은 동물 보호소에서 입양 보낸 동물의 정보를 담은 테이블입니다. ANIMAL_OUTS 테이블 구조는 다음과 같으며, ANIMAL_ID, ANIMAL_TYPE, DATETIME, NAME, SEX_UPON_OUTCOME는 각각 동물의 아이디, 생물 종, 입양일, 이름, 성별 및 중성화 여부를 나타냅니다. ANIMAL_OUTS 테이블의 ANIMAL_ID는 ANIMAL_INS의 ANIMAL_ID의 외래 키입니다.

 

보호소에서 중성화 수술을 거친 동물 정보를 알아보려 합니다. 보호소에 들어올 당시에는 중성화1되지 않았지만, 보호소를 나갈 당시에는 중성화된 동물의 아이디와 생물 종, 이름을 조회하는 아이디 순으로 조회하는 SQL 문을 작성해주세요.

 

  • 예시

예를 들어, ANIMAL_INS 테이블과 ANIMAL_OUTS 테이블이 다음과 같다면

 

ANIMAL_INS

ANIMAL_OUTS

  • Cookie는 보호소에 들어올 당시에 이미 중성화되어있었습니다.
  • Maxwell 2는 보호소에 들어온 후 중성화되었습니다.
  • Kaila는 보호소에 들어올 당시에 이미 중성화되어있었습니다.
  • Chewy는 보호소에 들어온 후 중성화되었습니다.

따라서 SQL문을 실행하면 다음과 같이 나와야 합니다.

 

문제풀이

SELECT I.ANIMAL_ID, I.ANIMAL_TYPE, I.NAME
FROM ANIMAL_INS I JOIN ANIMAL_OUTS O
USING (ANIMAL_ID)
WHERE I.SEX_UPON_INTAKE NOT LIKE O.SEX_UPON_OUTCOME
ORDER BY I.ANIMAL_ID

 

풀이설명

ANIMAL_INS테이블의 SEX_UPON_INTAKE과 ANIMAL_OUTS테이블의 SEX_UPON_OUTCOME의 데이터 값이 다른경우를 구하면 되는 문제이다.

INNER JOIN을 한 후 WHERE절에 NOT LIKE를 사용했다. ( =!, NOT IN 이조건도 허용된다.)

 

※ USING과 ON의 차이점

JOIN시 컬럼을 묶을 때 사용하는 것인데

JOIN할 테이블의 PK명과 FK명이 같다면 USING을 사용할 수 있다.

만약 다르다면 ON을 사용하여야 한다!

프로그래머스 level 3 : 오랜 기간 보호한 동물(2)

  • 문제설명

ANIMAL_INS 테이블은 동물 보호소에 들어온 동물의 정보를 담은 테이블입니다. ANIMAL_INS 테이블 구조는 다음과 같으며, ANIMAL_ID, ANIMAL_TYPE, DATETIME, INTAKE_CONDITION, NAME, SEX_UPON_INTAKE는 각각 동물의 아이디, 생물 종, 보호 시작일, 보호 시작 시 상태, 이름, 성별 및 중성화 여부를 나타냅니다.

ANIMAL_OUTS 테이블은 동물 보호소에서 입양 보낸 동물의 정보를 담은 테이블입니다. ANIMAL_OUTS 테이블 구조는 다음과 같으며, ANIMAL_ID, ANIMAL_TYPE, DATETIME, NAME, SEX_UPON_OUTCOME는 각각 동물의 아이디, 생물 종, 입양일, 이름, 성별 및 중성화 여부를 나타냅니다. ANIMAL_OUTS 테이블의 ANIMAL_ID는 ANIMAL_INS의 ANIMAL_ID의 외래 키입니다.

입양을 간 동물 중, 보호 기간이 가장 길었던 동물 두 마리의 아이디와 이름을 조회하는 SQL문을 작성해주세요. 이때 결과는 보호 기간이 긴 순으로 조회해야 합니다.

 

  • 예시

예를 들어, ANIMAL_INS 테이블과 ANIMAL_OUTS 테이블이 다음과 같다면

 

ANIMAL_INS

ANIMAL_OUTS

SQL문을 실행하면 다음과 같이 나와야 합니다.

※ 입양을 간 동물이 2마리 이상인 경우만 입력으로 주어집니다.

 

문제풀이

SELECT I.ANIMAL_ID, I.NAME
FROM ANIMAL_INS I
    JOIN ANIMAL_OUTS O
    ON I.ANIMAL_ID = O.ANIMAL_ID
ORDER BY O.DATETIME - I.DATETIME DESC   
LIMIT 2

 

풀이설명

우선 ANIMAL_INS테이블과 ANIMAL_OUTS테이블을 INNER JOIN을 한 후 

ANIMAL_OUTS테이블의 DATETIME과 ANIMAL_INS의 ANIMAL_INS을 빼서 내림차순으로 정렬을 한다.

LIMIT을 사용해 2개의 데이터를 뽑아낸다.

브라우저 객체란 ?

말 그대로 브라우저에 내장된 객체를 의미한다. 브라우저 객체의 최상위 객체는 window 객체이며, window 객체는 하위객체가 포함되어 있다. 즉, 계층적 구조이며, 이를 BOM(Browser Object Model)이라고 한다.

 

window 객체의 메서드 종류

종류 설명
open("URL","새 창 이름", "새 창 옵션") URL 페이지를 새 창으로 나타낸다.
alert() 경고창을 나타내고, 데이터를 보여준다. 방문자가 [확인]버튼을 누르면 alert()를 사용한 다음 위치의 코드를 수행한다.
prompt("질문", "답변") 질문과 답변으로 질의응답 창을 나타낸다.
confirm("질문내용") 질문 내용으로 확인이나 취소창을 나타낸다.
[확인] 버튼 = true를 반환
[취소] 버튼 = false를 반환
moveTo(x,y) 지정한 새 창의 위치로 이동한다.
resizeTo(width, htight) 지정한 새 창의 크기를 변경한다.
setInterval(function() { 자바스크립트 코드}, 일정시간간격) 지속적으로 일정한 시간 각격으로 함수를 호출한다.
setTimeout(function() { 자바스크립트 코드}, 일정시간간격) 단 한 번 일정한 시간 간격으로 함수를 호출한다.

메서드 사용 예

 

- open() : 새 창을 열어준다. 필자는 팝업창을 나타낼 때 사용하였다.

window.open("http://www.naver.com", "naver", "width=350, height=450, left=50, top=10, scrollbars=no");

 

- close() : 예를 들어 버튼이 있다는 가정하에 버튼을 클릭하면 창을 닫아준다.

<button onclick="window.close()"></button>

 

- alert() : 경고창을 나타낸다.

alert("삐빅! 잘못됬습니다");

 

- prompt() : 질의 응답 창을 나타낸다. 

prompt("당신의 나이는 ? ", "0");

 

- confirm() : 확인 / 취소창을 나타낸다. 확인버튼 : true를 return, 취소버튼 : false를 return

confirm("탈퇴하시겠습니까?");

 

- setInterval() : 일정 시간 간격으로 함수를 실행시킨다.

- clearInterval() :  setInterval() 메서드를 취소시킨다.

 

- setTimeout() : 단 한번만 일정시간이 지나면 코드를 실행하고 종료한다.

var auto = setTimeout(() =>{
             addNum++;
             console.log("setTimeout addNum : "+ addNum); 
         }, 5000);

 

 

 

프로그래머스 level 1 : 하샤드 수 

 

  • 문제설명

양의 정수 x가 하샤드 수이려면 x의 자릿수의 합으로 x가 나누어져야 합니다. 예를 들어 18의 자릿수 합은 1+8=9이고, 18은 9로 나누어 떨어지므로 18은 하샤드 수입니다. 자연수 x를 입력받아 x가 하샤드 수인지 아닌지 검사하는 함수, solution을 완성해주세요.

 

  • 제한사항

x는 1 이상, 10000 이하인 정수입니다.

 

  • 입출력 예

 

문제풀이

class Solution {
    public boolean solution(int x) {
        boolean answer = true;

        String temp = x+"";
        String [] temps = temp.split("");
        int num = 0;
        for(int i = 0; i<temps.length; i++){
            num += Integer.parseInt(temps[i]);
        }

        if(x%num != 0){
            answer = false;
        }

        return answer;
    }
}

 

풀이설명

파라미터로 넘어온 값을 배열에 담기 위해 String으로 변환 후 split을 사용하여 배열에 담는다.

더한 수를 저장하기 위한 변수를 선언한다.

for문을 사용하여 선언한 변수에 배열의 값을 더해준다.

조건을 걸어 나머지가 0이 아닐 경우 answer의 값을 false로 변경한다.

프로그램이란?

컴퓨터가 사람의 일을 할 수 있도록 해주는 것

컴퓨터에 처리되는 작업의 순서를 논리적으로 명령어로 작성하는 것

사용자의 명령에 반응하는 소프트웨어(프로그래밍의 결과문)

 

Java언어의 좋은 점

플랫폼 독립적이라서 여러 운영체제나 하드웨어에서도 동일하게 실행된다.

많은 오픈소스 프레임워크로 생산성을 증가하고 유지보수 비용을 절감할 수 있다.

간결하면서도 강력한 객제지향언어이다.

이식성 우수, 라이브러리 지향성, 보안성, 멀티스레드, 가상머신(JVM), 바이트코드

 

객체지향언어(Object Oriented Programming)의 장단점

*장점

 

캡슐화

필요한 속성과 행위를 하나로 묶고 그중 일부를 외부에서 사용하지 못하도록 은닉한다.

관련된 코드와 데이터가 묶여있고 오류가 없어 사용이 편리합니다. 데이터를 감추고(private) 외부 세계와의 상호작용은 메서드(getter, setter)를 통하는 방법인데, 라이브러리로 만들어 업그레이드하면 쉽게 바꿀 수 있습니다.

 

상속(extends)

이미 작성된 클래스를 이어받아서 새로운 클래스를 생성하는 기법으로 기존 코드를 재활용해서 사용하는 것을 의미한다.

 

다형성(polymorphism)

하나의 이름으로 많은 상황에 대처하는 기법.(하나의 객체가 여러가지 타입을 가질수 있는 것)

개념적으로 동일한 작업을 하는 함수들에 똑같은 이름을 부여할 수 있다.

조상클래스의 인스턴스를 이용하여 자손타입의 클래스를 다룬다거나, 메서드 오버로딩을 통하여 동일이름의 메서드를 이용하여 다양한 형태의 파라미터를 다루는 것.

  • 참조글 : https://chlee21.tistory.com/70?category=935054

 

*단점

개발 설계의 복잡함, 느려지는 런타임 속도

 

자바의 데이터 타입인 Primitive Type과 Reference Type이란?

데이터타입 설명
Primitive Type 기본형 타입으로 변수에 값 자체를 저장한다.
기본값이 있기때문에 Null이 존재하지 않는다. Null을 넣고 싶다면 래퍼클래스를 활용한다.
실제 값을 저장하는 공간으로 스택(Stack) 메모리에 저장된다.
컴파일시 담을수 있는 크기를 벗어나면 컴파일에러가 발생한다.
byte(1), short(2), char(2), int(4), long(8), float(4), double(8), boolean(2) 총 8가지이다.
Reference Type 참조형 타입으로 메모리상에 객체가 있는 위치를 저장한다.
빈 객체를 의미하는 Null이 존재한다.
값이 저장되어 있는 곳의 주소값을 저장하는 공간 힙(Heap) 메모리에 저장된다.
클래스타입, 열거타입, 인터페이스타입, 배열타입이 있다. 할당메모리크기 (4)

 

배열과 컬렉션의 차이점

배열은 하나의 자료형만 저장할 수 있고 크기가 고정적이다.

컬렉션은 복수의 자료형을 저장할 수 있고 크기가 가변적이다.

 

멀티스레드의 장단점

두 가지 이상의 작업을 동시해 실행 할 수 있어 자원을 효율적으로 이용할 수 있으나 dead lock 및 동기화에 대한 철저한 검증이 필요하다.

 

멀티스레드 구현방법

Thread 클래스를 상속(단일상속만 가능)받는법과 Runnable 인터페이스를 상속(다중상속 가능)받는법

  • 참조글 : https://chlee21.tistory.com/7?category=935054

 

Java 컬렉션의 대표 인터페이스는 ?

List : 순서가 있는 데이터의 집합으로 중복을 허용한다.

구현클래스 - ArrayList, LinkedList, Stack, Vector

 

Set : 순서를 유지하지 않는 데이터의 집합으로 중복을 허용하지 않는다.

구현클래스 - HashSet, TreeSet

 

Map : 키와 값이 쌍으로 이루어진 데이터의 집합으로 순서는 유지되지 않으면 키는 중복을 허용하지 않고 값은 중복을 허용한다.

구현클래스 - TreeMap, HashMap, HashTeble, Properties

 

컬렉션 List 인터페이스를 구현한 ArrayList 컬렉션 클래스란 ?

가변적 크기이다.

순차적으로 요소 값을 저장한다.

중복 요소 값을 허용한다.

 

 

컬렉션에 제네릭이 추가된 이유

컬렉션엔 다향한 데이터 타입이 들어갈 수 있는데 이를 명확하게 표시하기 위해 제네릭이 추가되었다.

컬렉션은 복수개의 데이터 타입 요소값이 저장되다 보니 원하는 자료형 타입 요소값을 추출하기 어렵다.

그러므로 지정한 자료형 타입 한가지만 저장하기 위해서 나온 것이 제네릭이다.

 

접근제어자의 종류와 특성

public : 접근 제한이 없다.

protected : 같은 패키지 내에서, 그리고 다른패키지의 자손클래스에서 접근가능

default : 같은 패키지 내에서만 접근가능

private : 같은 클래스 내에서만 접근가능

 

접근허용범위 : public > protected > default > private

 

Wrapper 클래스란 무엇인가?

primitive 타입으로 표현할 수 있는 간단한 데이터를 객체로 만들어야할 경우가 있는데 그러한 기능을 지원하는 클래스

byte Byte
short Short
int Integer
long Long
char Charater
float Float
double Double
boolean Boolean

 

추상클래스란 ?

클래스를 설계도에 비유하자면 추산클래스는 미완성 설계도에 비유할 수 있다.

미완성 설계도란, 단어의 뜻 그대로 완성되지 못한 채로 남겨진 설계도를 말한다.

클래스가 미완성이라는 것은 멤버의 개수에 관계된 것이 아니라, 단지 미완성 메서드(추상메서드)를 포함하고 있다는 의미이다. 미완성 설계도로 완성된 제품을 만들 수 없듯이 추상클래스로 인스턴스는 생성 할 수 없다. 추상클래스는 상속을 통해서 자손클래스에 의해서만 완성될 수 있다.

 

1. 추상클래스는 뭐? 실체클래스의 공통적인 부분(변수,메서드)를 추출해서 선언한 클래스

2. 추상클래스는 객체를 생성할 수 없다! 아직은 실체성이 없고 구체적이지 않기 때문에!

3. 추상클래스와 실체클래스는 어떤관계? 상속관계!

 

추상클래스 사용이유

1. 공통된 필드와 메서드를 통일할 목적

2. 실체클래스 구현시, 시간절약

3. 규격에 맞는 실체클래스 구현

 

인터페이스란 ?

자바의 다형성을 극대화하여 개발코드 수정을 줄이고 프로그램 유지보수성을 높이기 위해 사용한다.

인터페이스는 일종의 추상클래스이다. 인터페이스는 추상클래스처럼 추상메서드를 갖지만 추상클래스보다 추상화정도가 높아서 추상클래스와는 달리 몸통을 갖춘 일반 메서드 또는 멤버변수를 구성원으로 가질 수 없다. 

오직 추상메서드와 상수만을 멤버로 가질 수 있으며, 그 외 어떠한 요소도 허용하지 않는다. 추상클래스를 부분적으로 완성된 '미완성 설계도'라고 한다면, 인터페이스는 구현된 것은 아무것도 없고 밑그림만 그려져 있는 '기본 설계도'라고 말 할 수 있다. 인터페이스는 인터페이스로부터만 상속받을 수 있으며, 클래스와 달리 다중상속, 즉 여러개의 인터페이스로부터 상속을 받는 것이 가능하다.

 

자바의 GUI에서 스윙과 AWT의 차이점

AWT(Abstract Window Toolkit)는 운영체제가 갖고 있는 각 컴포넌트를 이용한다. 즉 운영체제에 종속적인 GUI로서 운영체제 종류에 따라 화면에 출력되는 모양이 약간씩 다르다.

스윙은 운영체제가 갖고 있는 GUI를 사용하지 않고 자바 가상머신의 Swing패키지를 직접 사용해 구현한다.

따라서 운영체제가 달라도 동일한 화면을 출력하게된다. 스윙이 AWT보다 세련되고 다양한 GUI를 제공해주기 때문에 자바 어플GUI개발에서는 AWT보다 스윙을 더 많이 사용한다.

 

가비지 콜렉터란 ?

Garbage Collection은 동적 할당된 메모리 영역(Heap) 가운데 더이상 사용할 수 없게 된 영역을 탐지하여 자동으로 해제하는 기법이다. 쓰레기 수집이 지원되는 환경에서는 프로그래머가 동적으로 할당한 메모리 영역의 전체를 완벽하게 관리할 필요가 없어진다. 이러한 작업은 CLR의 '가비지컬렉터'라는 일종의 백그라운드 서비스를 통해 자동으로 이뤄진다.

 

오버로딩과 오버라이딩의 차이점

오버로딩 : 메소드의 이름은 같지만 데이터 형식이나 매개변수의 개수를 다르게 정의하는 것

오버라이딩 : 기존의 메소드를 재정의 하는 것으로 데이터 형식이나 매개변수의 개수가 같아야 한다.

 

Exception 이란?

프로그램의 비정상적인 종료나 중단을 막을 수 있다.

RuntimeException(실행시 발생하는 예외)이나 그 외 Exception(컴파일시 발생하는 예외)으로 나눌 수 있다.

직접 처리하는 방식은 try ~ catch

다음 처리할 곳으로 넘기는 방식은 throws

 

동기화란 ?

하나의 자원을 여러 태스크가 사용하려 할 때, 한 시점에서 하나의 태스크만 사용할 수 있도록 하는 것.

 

프로세스와 쓰레드의 차이점

프로세스 : 실행 중인 프로그램, 자원과 쓰레드로 구성

쓰레드 : 프로세스 내 실제 작업을 수행하는 단위, 모든 프로세스는 하나 이상의 쓰레드를 가지고 있다.

멀티쓰레드 : 하나의 프로세스에 하나 이상의 쓰레드를 생성하여 실행

 

프로그래머스 level 1 : 수박수박수박수박수박수?

 

  • 문제설명

길이가 n이고, "수박수박수박수...."와 같은 패턴을 유지하는 문자열을 리턴하는 함수, solution을 완성하세요. 예를들어 n이 4이면 "수박수박"을 리턴하고 3이라면 "수박수"를 리턴하면 됩니다.

  • 제한조건

n은 길이 10,000이하인 자연수입니다.

 

  • 입출력 예

 

문제풀이

class Solution {
    public String solution(int n) {
        String answer = "";
        for(int i=0; i<n/2; i++) answer += "수박";
        if(n%2 != 0) answer += "수"; 

        return answer;
    }
}

 

풀이설명

for문을 사용(i의 크기는 파라미터의 값/2)하여 "수박"을 넣어준 후 조건문을 사용하여(파라미터의 값이 홀수일 경우) "수"를 더해준다.

프로그래머스 level 1 : 가운데 글자 가져오기

 

  • 문제설명

단어 s의 가운데 글자를 반환하는 함수, solution을 만들어 보세요. 단어의 길이가 짝수라면 가운데 두글자를 반환하면 됩니다.

  • 제한조건

s는 길이가 1 이상, 100이하인 스트링입니다.

 

  • 입출력 예

 

문제풀이

class Solution {
    public String solution(String s) {
        String answer = "";
        int num = s.length();
        int num2 = num/2;
        if(num % 2 == 0){
            answer = s.substring(num2-1, num2+1);
        }else{
            answer = s.substring(num2, num2+1);
        }
        return answer;
    }
}

 

풀이설명

파마리터로 넘어온 변수의 길이를 구한 후 2로 나눈다.

조건문을 주어 길이가 짝수일 경우(num % 2 == 0) substring함수를 사용하여 num2-1, num2+1로 문자열을 자른다.

아닐 경우 num2, num2+1로 문자열을 자른다.

프로그래머스 level 1 : 문자열 내림차순으로 배치하기

 

  • 문제설명

문자열 s에 나타나는 문자를 큰것부터 작은 순으로 정렬해 새로운 문자열을 리턴하는 함수, solution을 완성해주세요.
s는 영문 대소문자로만 구성되어 있으며, 대문자는 소문자보다 작은 것으로 간주합니다.

  • 제한조건

str은 길이 1 이상인 문자열입니다.

 

  • 입출력 예

 

문제풀이

class Solution {
    public String solution(String s) {
        String answer = "";
        char [] arr = s.toCharArray();
        char temp;
        for (int i=0; i<arr.length-1; i++){
            for(int j=i+1; j<arr.length; j++){
                if(arr[i] < arr[j]){
                    temp = arr[i];
                    arr[i] = arr[j];
                    arr[j] = temp;
                }
            }
        }
        for(int i=0; i<arr.length; i++){
            answer += arr[i];
        }
        
        return answer;
    }
}

 

풀이설명

toCharArray() 메소드를 사용하여 배열에 담는다.

sorting을 위해 char형 변수를 선언 후 이중for문을 사용하여 배열을 정렬한다.

정렬한 배열의 값을 String 변수에 값을 넣어준 후 리턴한다.

프로그래머스 level 1 : 정수 내림차순으로 배치하기

 

  • 문제설명

함수 solution은 정수 n을 매개변수로 입력받습니다. n의 각 자릿수를 큰것부터 작은 순으로 정렬한 새로운 정수를 리턴해주세요. 예를들어 n이 118372면 873211을 리턴하면 됩니다.

  • 제한조건

n은 1이상 8000000000 이하인 자연수입니다.

 

  • 입출력 예

 

문제풀이

class Solution {
    public long solution(long n) {
        long answer = 0;
        String nstr = String.valueOf(n);
        char [] narr = nstr.toCharArray();
        char temp;
    
        for (int i=0; i<narr.length-1; i++){
            for(int j=i+1; j<narr.length; j++){
                if(narr[i] < narr[j]){
                    temp = narr[i];
                    narr[i] = narr[j];
                    narr[j] = temp;
                }
            }
        }
        nstr = "";
        for(int i=0; i<narr.length; i++){
            nstr +=narr[i];
        }
        answer = Long.parseLong(nstr);
        
        return answer;
    }
}

 

풀이설명

String.valueOf() 메소드를 사용하여 파라미터로 넘어온 정수를 String형으로 변환 후 toCharArray() 메소드를 사용하여 배열에 담는다.

sorting을 위해 char형 변수를 선언 후 이중for문을 사용하여 배열을 정렬한다.

정렬한 배열의 값을 String 변수에 값을 넣어준 후 Long.parseLong()함수를 사용하여 long형으로 변환 후 리턴한다.

+ Recent posts