분류 전체보기 94

[JAVA] 람다식

람다식이란? 간단하게 말해서 메서드를 하나의 식으로 표현한 것이다. 람다식은 함수를 간략하면서도 명확한 식으로 표현할 수 있게 해준다. 메서드를 람다식으로 표현하면 메서드의 이름과 변환값이 없어지므로, 람다식을 익명함수라고도 표현한다. int[] arr = new int[5]; Arrays.setAll(arr, (i) -> (int)(Math.random()*5+1); /*위 람다식이 하는 일을 메서드로 표현하면 아래와 같다*/ int method(){ return (int)(Math.random()*5) +1; } 위 코드를 보면 메서드보다 람다식이 간경하면서도 이해하기 쉽다는 것에 이견이 없을 것이다. 게다가 모든 메서드는 클래스에 포한되어야 하므로 클래스도 새로 만들어야 하고, 객체도 생성해야만 비..

카테고리 없음 2023.03.15

[ JAVA ] 쓰레드란?

먼저, 쓰레드를 설명하기전에 프로세스부터 알아보자! 프로세스란? 간단히 말하자면 실행 중인 프로그램 이다. 운영체제로 부터 시스템 자원(메모리)을 할당받는 작업의 단위이며 실행된 프로그램을 의미한다. 프로세스의 구성 프로세스 = 실행중인 프로그램 (자원[데이터 + 메모리] + 쓰레드) 할당 시스템 자원 CPU시간, 운영시 필요한 주소공간 Code, Data, Stack, Heap 의 구조로 되어있는 독립된 메모리 영역이 있다. 특징 - 프로세스는 각각 독립된 메모리 영역 (Code, Data, Stack, Hea) 구조를 할당 받고, 최소 1개의 메인 쓰레드를 가지고 있다. - 각 프로세스는 별도의 주소공간에서 실행되며, 한 프로세스는 다른 프로세스의 변수나 자료구조에 접근 할 수 없다. - 한 프로세스..

[JAVA] Collections

Collections 를 배우기 전, 컬렉션의 중복되는 의미들을 살펴봅시다. collection: 객체가 저장되고 반복되는 자료 구조를 나타냄 Collection: Set, List, Queue가 상속받는 java.util.Collection 인터페이스이다. 이는 상속임. 구현이 아니라. 즉, Collection를 직접 구현한 것은 없음. Collections(대문자 C, s로 끝남): collections에 사용할 정적 유틸리티 메소드의 모음이 있는 java.util.Collections 클래스이다. 특징 - 컬렉션 프레임워크 타입의 객체에서 사용하거나 컬렉션을 반환하는 static 메소드들로 구성되어있음. → 쉽게 말해 컬렉션 프레임워크 타입의 객체(중복되는 의미에서 1번)에 대한 객체생성, 정렬, ..

카테고리 없음 2023.02.01

[JAVA] Properties 란?

Properties 란? Properties는 HashMap의 구버전인 Hashtable을 상속받아 구현한 것으로, Hashtable은 키와 값을 (Object, Object)의 형태로 저장하는데 비해 Properties는 (String, String)형태로 저장하는 보다 단순화된 컬렉션 클래스이다. 주로 애플리케이션의 환경설정과 관련된 속성을 저장하는데 사용되며 데이터를 파일로부터 읽고 쓰는 편리한 기능을 제공한다. 그래서 간단한 입출력은 Properties를 활용하면 몇 줄의 코드로 쉽게 해결할 수 있다. 간단한 예제로 사용하는 방법을 알아보자! public class PropertiesEx1 { public static void main(String[] args) { Properties prop =..

[JAVA] TreeMap 이란

TreeMap은 이진트리를 기반으로 한 Map 컬렉션이다. TreeSet과의 차이점은 TreeSet은 값만 저장 한다. 하지만 TreeMap은 키와 값의 쌍으로 이루어진 데이터를 저장한다. 그래서 검색과 정렬에 적합한 컬렉션 클래스이다. TreeMap은 일반적으로 HashMap보다 성능이 떨어진다. TreeMap은 데이터를 저장할 때 즉시 정렬하기에 추가나 삭제가 HashMap보다 오래 걸린다. 하지만 정렬된 상태로 Map을 유지해야 하거나 정렬된 데이터를 조회해야 하는 범위 검색이 필요한 경우 TreeMap을 사용하는 것이 효율성면에서 좋다. TreeMap 사용방법 TreeMap 선언 //TreeMap생성 TreeMap tmap1 = new TreeMap(); //타입 파라미터 생략가능 TreeMap ..

[JAVA] LinkedList

배열은 가장 기본적인 형태의 자료구조로 구조가 간단하고, 사용하기 쉽고 데이터를 읽어오는데 걸리는 시간이 가장 빠릅니다. 하지만 단점도 있다. 1. 크기를 변경할 수 없다. - 크기를 변경할 수 없으므로 새로운 배열을 생성해서 데이터를 복사해야한다. - 실행속도를 향상시키기 위해서는 충분히 큰 크기의 배열을 생성해야 하므로 메모리가 낭비된다. 2. 비순차적인 데이터의 추가 또는 삭제에 시간이 많이 걸린다. - 차례대로 데이터를 추가하고 마지막에서부터 데이터를 삭제하는 것은 빠르지만, 배열의 중간에 데이터를 추가하려면, 빈자리를 만들기 위해 다른 데이터들을 복사해서 이동해야 한다. 위와 같은 배열의 단점을 보완하기 위해 나타난 자료구조가 LinkedList이다. 배열은 모든 데이터가 연속적으로 존재하지만 ..

[JAVA] ArrayList 사용방법

ArrayList란? ArrayList는 Object배열을 이용해서 데이터를 순차적으로 저장한다. 배열에 저장할 공간이 없다면 더 큰 새로운 배열을 선언하여 기존 배열의 내용을 복사하여 붙여놓은 다음 새로운 내용을 순서대로 저장한다. List 인터페이스를 상속받아 사용함. ArrayList는 객체가 추가되어 용량을 초과하면 자동으로 부족한 크기만큼 용량이 늘어남. 배열은 데이터를 추가, 삭제 시 반복문으로 인덱스를 한 칸씩 밀거나 당기는 식으로 공간을 조절하지만 ArrayList는 이 과정을 자동으로 처리해주어서 편리하게 사용이 가능함. 즉, 장점과 단점을 정리해 보자면 장점 데이터에 순서가 있음 데이터의 중복 저장 허용 index를 통한 검색 빠름 단점 데이터 추가, 삭제가 느림 ArrayList 선언..

[JAVA] 컬렉션 프레임워크(collection framework)

컬렉션 프레임 워크란? 다수의 데이터들을 저장하는 클래스들을 표준화한 설계를 뜻한다. 즉, 다수의 데이터를 쉽고 효과적으로 처리할 수 있는 방법들을 제공하는 클래스들의 집합을 의미한다. 컬렉션 프레임워크의 핵심 인터페이스 - List 인터페이스 - Set 인터페이스 - Map 인터페이스 이 중에서 List와 Set 인터페이스는 모두 Collection 인터페이스를 상속받지만, 구조상의 차이로 인해 Map 인터페이스는 별도로 정의됨. 인터페이스 설명 구현 클래스 List 순서가 있는 데이터의 집합으로, 데이터의 중복을 허용함. Vector, ArrayList, LinkedList, Stack, Queue Set 순서가 없는 데이터의 집합으로, 데이터의 중복을 허용하지 않음. HashSet, TreeSet ..

[IntelliJ] 인텔리제이 설치 방법

IntelliJ 설치 1. 사이트 접속!! https://www.jetbrains.com/idea/ IntelliJ IDEA – the Leading Java and Kotlin IDE IntelliJ IDEA is undoubtedly the top-choice IDE for software developers. It makes Java and Kotlin development a more productive and enjoyable experience. www.jetbrains.com 2. 다운로드 클릭!! 3. 버전 선택 * 참고 - intelliJ IDEA는 기업, 개인에 상관없이 무료로 이용이 가능하다! 하지만 버전에 따라 기능을 제한을 두었다. 😥 버전 종류 위 사진에서 보다시피 두 가지의 버..

Tools 2022.12.19

[JAVA] BigInteger , BigDecimal 클래스

정수형으로 표현할 수 있는 값의 한계가 있다. 가장 큰 정수형인 long 타입도 표현 할 수 있는 값이 10진수로 19자리이다. 이 것 보다 더 큰 값을 다뤄야할 때, BigInteger를 사용한다. BigInteger BigInteger 클래스는 내부적으로 int 배열을 사용해서 값을 다루기 때문에 long 타입보다 더 큰 값을 다룰 수 있다, BigInteger는 String 처럼 immutable 이다. 그리고 모든 정수형이 그렇듯이 BigInteger 역시 값을 2의 보수의 형태로 표현한다. BigInteger 의 생성 문자열로 숫자를 표현하는 것이 일반적이다. 정수형 리터럴로는 표현할 수 있는 값의 한계가 있기 때문이다. BigInteger val; val = new BigInteger("123..

728x90