자바 (17) 썸네일형 리스트형 [자바] 람다식 개념 및 표현법 람다(lambda )식 람다식은 식별자가 필요 없으며 익명 함수를 지칭하는 용어이다. 자바 8부터 람다식을 지원하며 문법이 간결하여 가독성 면에서 큰 장점을 불러온다.(람다를 쓰지말라는 상급자 분들도 있습니다.) 장점 코드가 간결하다 지연 연산을 통한 불필요한 연산을 최소화 한다. 멀티 쓰레드를 활용하여 병렬처리가 가능하다. 가독성이 향상된다. 단점 람다stream을 통한 단순 for문, while문 사용시 성능 저하가 발생 가능하다. 무명함수는 재사용이 불가능하다. 불필요한 람다식은 가독성을 떨어뜨린다.(비슷한 함수를 계속 중복생성할 수 있음) 디버깅하기 까다롭다. 람다식 표현법 (x, y) -> x x+1 (x) -> x+1 x -> x+1 (int x) -.. HashSet기초 (자바) Set은 객체를 중복해서 저장할 수 없고(자동으로 중복 제거), 하나의 null값만 저장 할 수 있으며, 저장 순서가 유지되지 않는다. (저장 순서를 유지하기 위해서는 JDK 1.4부터 제공하는 LinkedHashSet 클래스 이용) HashSet은 TreeSet과 다르게 자동 정렬이 되지 않는다 HashSet 선언 방법 HashSet h1 = new HashSet();//타입 지정 HashSet h2 = new HashSet();//new에서 타입 생략가능 HashSet h3 = new HashSet(h1);//h1의 모든 값을 가진 HashSet생성 HashSet h4 = new HashSet(10);//초기 용량(capacity)설정 HashSet h6 = new HashSet(Arrays.asLi.. Vector 기초 (자바) ArrayList와 동일한 내부 구조를 가지고 있지만 Vector는 항상 동기화된 메소드로 구성되어 있기 때문에 멀티 스레드가 동시에 메소드들을 실행할 수 없고, 하나의 스레드가 실행을 완료해야만 다른 스레드들이 실행 할 수 있다. 항상 동기화 되므로 스레드 환경에서의 안정성은 높지만 ArrayList와 비교하여 추가, 검색, 삭제의 성능은 떨어진다는 단점이 있다. Vector 선언 방법 Vector v = new Vector();//타입 설정x Object로 선언 Vector v1 = new Vector(); //타입설정 int타입만 사용가능 Vector v2 = new Vector(); //new에서 타입 파라미터 생략가능 Vector s = new Vector(10);//초기 용량(capacity).. Stack 기초 (자바) LIFO(Last In First Out) 구조이며, 깊이 우선 탐색(DFS), 재귀함수 호출에서 사용된다. Stack 선언 방법 Stack st = new Stack(); // 타입 설정x Object로 선언 Stack i = new Stack(); // Integer타입 선언 Stack i2 = new Stack(); // 타입 생략 가능 Stack s = new Stack(); // String타입 선언 Stack ch = new Stack(); // Char타입 선언 Stack 기초 명령어 예제 →Stack값 추가 public class Main { public static void main(String[] args) { Stack stack = new Stack(); //int형 스택 선언 st.. LinkedList 기초 (자바) 데이터는 포인터와 주소를 사용하여 연결되며, 데이터가 연속된 위치에 저장되지 않고 모든 데이터가 데이터 부분과 주소 부분을 별도로 가지고 있다. 각 데이터는 노드라 불리며 배열에서 자주 삽입, 삭제가 이루어지는 경우 용이하며, ArrayList보다 선호된다. 단점으로는 ArrayList보다 검색에 있어 느리다. LinkedList 선언 방법 LinkedList li = new LinkedList(); // 타입 설정x Object로 입력 LinkedList i = new LinkedList(); // int 타입으로 선언 LinkedList i2 = new LinkedList(); // 타입 선언 생략도 가능 LinkedList i3 = new LinkedList(Arrays.asList(1, 2, 3).. ArrayList 기초 (자바) 동적 배열을 제공하며, 컬렉션에서 개체를 추가, 삭제시 ArrayList의 크기가 자동으로 조정된다. 표준 배열보다는 느리지만 배열에서 많은 조작이 필요한 경우 유용하게 사용 가능하다. ArrayList 선언 방법 ArrayList i = new ArrayList(); // int 타입으로 선언 ArrayList i2 = new ArrayList(); // Integer 타입 사용 ArrayList i3 = new ArrayList(10); // 초기 용량 세팅 ArrayList i4 = new ArrayList(Arrays.asList(1, 2, 3, 4)); // 초기 값 세팅 ArrayList s = new ArrayList(); // 타입 생략 가능 ArrayList ch = new ArrayLi.. Collection(List, Set, Queue, Map) collection 인터페이스 인터페이스 클래스 특징 List ArrayList LinkedList Stack Vector 순서가 있는 데이터의 집합으로 데이터의 중복을 허용한다. Set HashSet SortedSet(TreeSet) 순서를 유지하지 않는 데이터의 집합으로 데이터의 중복을 허용하지 않는다. Queue LinkedList PriorityQueue 순서가 있는 데이터의 집합으로 데이터의 중복을 허용한다. Map Hashtable HashMap TreeMap 키(Key), 값(Value)의 쌍으로 이루어진 데이터으 집합으로, 순서는 유지되지 않으며 키(Key)의 중복을 허용하지 않으나 값(Value)의 중복은 허용한다. 이전 1 2 다음