본문 바로가기

JAVA

(187)
Singleton//싱글톤//기본 코드 1번문제 : MyClass에서 싱글턴을 통해 YouClass로 숫자 넘기기 2번문제 : YouClass에서 싱글턴을 통해 HeClass로 문자 넘기기 ->> 모두 Main에서 함수 호출 **Singleton : 하나의 instance에 접근하여 데이터를 송수신 할 수 있는 Patten 어디서든 호출하면 접근 가능. public class SingletonClass { private static SingletonClass sc=null; public int snumber; public String str_; private SingletonClass() { } public static SingletonClass getInstance() { if (sc == null) { sc = new SingletonCl..
stack//스택// 원리 코드 ArrayStrack 클래스 생성 1. 사이즈 입력받아 배열로 생성 2. 공간이 비어있나? -> return boolean 3. 공간이 꽉차있나? -> return boolean 4. 입력 (매개변수 : 입력받을item) 4-1. 공간이 가득찼나? 4-2. 빈공간? -> top++; stackArray[top]에 입력 5. 삭제 item = peek()// 최근에 추가된(Top) 데이터 조회, top--; return item; 6. 조회 6-1. 비어있나 ? isEmpty , return null; 6-2. return stackArray[top] public Element push(Element item); // 데이터 추가 public Element pop(); // 최근에 추가된(Top) 데이터 ..
Map//Baseball 야구멤버 public class MemberDao { Scanner sc = new Scanner(System.in); // 배열 // private Pitcher pitcher[]; // private Batter batter[]; // private Human human[] = new Human[20]; // 변수 20개 생성 // private ArrayList list = new ArrayList(); private Map map = new HashMap(); private int memberNumber; // private int memberCount; FileProc fp; public MemberDao() { fp = new FileProc("baseball"); fp.createFile(); // ..
함수//클래스에서 오버라이딩하여 변수 값 비교하기 (*헷깔림) 문제 : 다음과 같은 실행결과를 얻도록 Point3D클래스의 equals()를 멤버변수인 x, y, z 의 값을 비교하도록 오버라이딩하고, toString()은 실행결과를 참고해서 적절히 오버라이딩하시오. 실행결과 [1,2,3] [1,2,3] p1==p2?false p1.equals(p2)?true Point3D public class Point3D { int x,y,z; public Point3D(int x, int y, int z) { this.x=x; this.y=y; this.z=z; } public Point3D() { this(0,0,0); } public boolean equals(Object obj) { /* (1) 인스턴스변수 x, y, z를 비교하도록 오버라이딩하시오. */ Point3..
함수//상속//도형면적 반환 Circle도형 클래스와 Rectangle도형 클래스에 double calcArea()메서드를 오버라이드 생성해준다. 기본생성자에 지역변수를 만들고 오버라이드에 공식을 리턴값으로 지정해준다. (메인에서 오버라이드 호출하면 원, 사각형 상관없이 바로 계산될 수 있게) ( 부모클래스 Shape에 초기값을 설정하는 Point를 호출 ) Circle public class Circle extends Shape { double r; public Circle() { } public Circle(double r) { super(); this.r = r; } //무조건. @Override double calcArea() { return (r * r * Math.PI);//반지름 값으로 수정 } } Rectangle p..
HashMap 코드 "사과" : "apple" key : value -> 1pair == web json key:value Tree 구조 key 는 중복되지 않는다 List : 선형 구조 o-o-o-o-o-o-o TreeMap = HashMap + Sorting(key) 선언 HashMap hMap = new HashMap(); 추가 // 추가 key value hMap.put(111, "백십일"); hMap.put(222, "이백이십이"); hMap.put(333, "삼백삼십삼"); value확인 // value 취득 String value = hMap.get(222); System.out.println("value:" + value); or if(hMap.containsKey(333)) { value = hMap.get..
ArrayList 와 LinkedList ArrayList : 검색, 대입 == Vector LinkedList : 실시간 추가, 삭제의 처리가 빠르다 ArrayList에서 LindedList로 바꿔 사용하는것이 포인트 ArrayList alist = new ArrayList(); // list의 내용내용내용~ LinkedList blist = new LinkedList( alist ); //맨 앞의 element를 추가 blist.addFirst("giants"); //맨 뒤에 element를 추가 blist.addLast("bears"); main public class mainClass { public static void main(String[] args) { ArrayList alist = new ArrayList(); alist.ad..
interface//인터페이스 NameCard 방법1 interface 인 PrintNameCard 클래스를 만들어 나머지 카드1,2에 상속 후 오버라이딩 해줌 메인에서 NameCard 객체 ncard 생성 후 "이름","전화번호","이메일" 을 넣어준 후 ncard . setPrintNameCard (new PrintNameCard2()); 로 대입해준 후 print()로 호출하면 값이 나옴. NameCard에 인터페이스 PrintNameCard PrintNameCard 객체 생성 후 setPrintNameCard 메서드를 만들어 들어오는 매개변수 PrintNameCard p 값을 this . PrintNameCard에 새로 저장, print메서드를 생성해 printNameCard.print( this ); -> this를 출력. PrintName..