기본 콘텐츠로 건너뛰기

scala 5. class

1. 클래스

scala> class Counter {
     |   private var value = 0
     |   def increment() { value += 1 }
     |   def current() = value
     | }
defined class Counter

앞에서 했던 내용들하고 비교해보면 특별한건 없어보인다.
단 파라미터가 없는 메소드의 경우 가급적 '( )' 없이 사용하길 권장한다고 한다.

2. 게터와 세터 자동생성

scala> class Person { var age =0 }
defined class Person

scala> val chang = new Person
chang: Person = Person@157fe3d

class 내부에 age라는 변수만 초기화 해놨다.
별다른 표시가 없으면 멤버 접근권한은 기본적으로 public으로 존재한다.

scala> chang.age
res9: Int = 0

scala> chang.age = 1
chang.age: Int = 1

scala> chang.age
res10: Int = 1

이부분이 조금 매력적이다.
사용할때는 .age 하나인데, 이걸로 setter도 되고 getter의 기능도한다.
scala에서는 만약 멤버변수 int타입 age가 생성되면

getter는 int age() = age
setter는 void age_=(int)

의 형식으로 자동으로 내부적으로 생성한다.
그리고 멤버 변수가 var가 아닌 val으로 선언했다면
그 멤버의 setter는 생성되지 않는다.
또한 getter와 setter는 자동으로 생성은 됬지만,
입맛에 맞게 수정하여 사용할 수 도 있다.


3. 비공개필드

클래스에서 일부 필드를 비공개로 숨기는 기능이 있다.
대게 private한 변수들도 메소드내에서는 접근이 가능하다.
그런데 여기서는 이걸 불가능하게 하는 방법이 있다.

private[this] var value = 0
def isLess(other : Counter) = value < other.value

private뒤에[this] 라는 키워드를 덧붙이면 된다. 이렇게되면
other.value에 접근할수 없다는 에러메세지가 표시된다.


4. @BeanProperty

getValue, setValue를 명시적으로 생성해주는 키워드다.
class Person{
  @BeanProperty var name ="foo"
}
private으로 선언할 수 없다.

scala> var p = new Person
p: Person = Person@15b5d86
scala> p.name
res44: String = foo
scala> p.setName("qq")
scala> p.getName()
res46: String = qq

5. 보조생성자 : this
scala에서는 기본생성자외에 this 로 표시되는 보조생성자가 추가로 있어서
클래스는 원하는 대로 생성자를 만들 수 있다.
단 보조생성자는 이전에 정의한 보조생성자나 기본 생성자 호출로 시작해야한다.
scala> class Person {
     |   private var name = ""
     |   private var age = 0
     |
     |   def this(name : String) {
     |     this() // 기본생성자                                                                                                                                                                
     |     this.name = name
     |   }
     |
     |   def this(name : String, age : Int){
     |     this(name)
     |     this.age = age
     |   }
     | }
defined class Person


scala> val p1 = new Person
p1: Person = Person@c5dbb

scala> val p2 = new Person("Fred")
p2: Person = Person@30e71

scala> val p3 = new Person("Fred",42)
p3: Person = Person@1aabda3

6. 기본생성자
클래스 파라미터 값을 받는다.
scala> class Person (val name : String, val age : Int) {
     | }
defined class Person

scala> val p5 = new Person("bob", 32)
p5: Person = Person@e25ef0

scala> p5.name
res15: String = bob

scala> p5.age
res16: Int = 32

setter, getter 만들 필요도 없으니, 파라미터값만 설정해주면 끝.

기본생성자는 클래스 정의에 있는 모든 문을 실행한다.
클래스에 내에 print 함수가 있다면 새로운 객체가 생성될때마다 다음처럼 된다.

scala> class Person (val name : String, val age : Int) {
     |   println("Just constructed another person" + name);
     | }
defined class Person

scala> val p6 = new Person("Alice", 22)
Just constructed another personAlice
p6: Person = Person@d3e5cc

7. 중첩클래스

스칼라에서는 함수안에 다른함수, 클래스 안에 다른클래스를 정의할 수 있다.
scala> class Network{
     |   class Member(val name:String){
     |     val contacts = new ArrayBuffer[Member]
     |   }
     |
     |   private val members = new ArrayBuffer[Member]
     |
     |   def join(name: String) = {
     |     val m = new Member(name)
     |     members += m
     |     m
     |   }
     | }
defined class Network

scala> val chatter = new Network
chatter: Network = Network@dacf27

scala> val myFace = new Network
myFace: Network = Network@18a36e6

chatter, myFace내에 Member 클래스는 당연히 서로 다른거다.
Network내에서 자신의 Member를 추가할수는 있지만 다른 Network간에는 불가능하다.

scala> val fred = chatter.join("Fred")
fred: chatter.Member = Network$Member@61d064

scala> val wilma = chatter.join("Wilma")
wilma: chatter.Member = Network$Member@1a87caa

scala> fred.contacts += wilma
res20: fred.contacts.type = ArrayBuffer(Network$Member@1a87caa)

scala> val barney = myFace.join("Barney")
barney: myFace.Member = Network$Member@509953

scala> fred.contacts += barney
<console>:14: error: type mismatch;
 found   : myFace.Member
 required: chatter.Member
              fred.contacts += barney



댓글

이 블로그의 인기 게시물

메일서버가 스팸으로 취급받을때

설치한 메일서버를 통해 발송되는 메일이 스팸으로 들어가는 경우가 더러 있다. 이게 한번 들어가기는 쉬운데, 빠져나오기는 드럽게 힘든것 같다... 본인의 경우에는 우선 국내서비스에는 별 무리 없이 들어간다. (naver,daum 등) 그런데 해외메일 그중 Gmail, Hotmail 에는 에누리없이 스팸으로 간주되고 있었다. Gmail같은 경우에는 그래도 스팸함으로 발송은 제대로 되는반면에 Hotmail같은경우에는 아예 수신자체가 안되는 경우도 더러있다.. ㅡ,.ㅡ; 제일 좋은 방법은 Gmail,Hotmail에 전화걸어서 우리 메일서버 IP white Ip로 등록해달라!!! 하면 좋지만, 얘네들은 걸어봤자 자동응답기고, 문의채널은 구글 그룹스 게시판이 전부다.. 본론으로 들어가서. 해외 메일이 차단될 경우 내 매일서버ip가 스팸ip로 등록되 버린 경우일 수 있다. (본인처럼. ㅎ) 이것부터 조회 해보고 싶으면 RBL(real-time blocking List) 체크를 해야 하는데, RBL체크 해주는 사이트는 꽤 많이 있고, 그중 좀 깔끔해 보이는곳 하나 소개. http://www.anti-abuse.org/ 메일서버ip 입력하고 조회해보면 쭈루룩 리스트가 나온다. 그 중 빨간불이 들어온 부분이 메일 서버가 스팸서버가 된 각종 이유들이다.ㅋ 본인의 경우 CBL 때문에 걸렸는데, 내용은 아래와 같다. This IP address is HELO'ing as  "localhost.localdomain"  which violates the relevant standards (specifically: RFC5321). 메일서버 도메인에 별다른 작업을 안해놓아서 "localhost.localdomain" 으로 설정되어있었다. 만약 CBL만 바로 테스트 해보고 싶으면 http://cbl.abusea

[javascript] 특정시간에만 함수 실행

특정시간에만 팝업을 띄우려면?? 특정시간에만 로그인을 막으려면?? 특정시간에만 할일은 의외로 참 많다. 방법? 딱히 없다. 현재시간 구해서 시작시간, 종료시간 사이에 있을때 시작하는 수밖엔. if ((현재시간 > 시작시간) && (현재시간 < 종료시간)){ .. 팝업노출(); 공사페이지 리다이렉트(); 기타등등(); .. } 자바스크립트로 작성하면 다음과 같다. var startdate = "2014012008" ; var enddate = "2014012418" ; var now = new Date (); //현재시간 year = now. getFullYear (); //현재시간 중 4자리 연도 month = now. getMonth () + 1 ; //현재시간 중 달. 달은 0부터 시작하기 때문에 +1 if ((month + "" ). length < 2 ){ month = "0" + month; //달의 숫자가 1자리면 앞에 0을 붙임. } date = now. getDate (); //현재 시간 중 날짜. if ((date + "" ). length < 2 ){ date = "0" + date; } hour = now. getHours (); //현재 시간 중 시간. if ((hour + "" ). length < 2 ){ hour = "0" + hour; } today = year + "" + month + "" + date + "" + hour; //오늘 날짜 완성. / / 시간비교 i

스레드 동기화1 - syncronized

구현 스레드를 구현하는 방법은 2가지다. 1. Thread 클래스를 extends 한다. 2. Runnable 인터페이스를 implements 한다. 뭐 사실 Thread는 생성자의 변수로 Runnable을 취한다. public Thread (Runnable target) { init( null, target , "Thread-" + nextThreadNum () , 0 ) ; } 그리고 Runnable 인터페이스는 run() 이라는 단일함수를 갖는 인터페이스이다. @FunctionalInterface public interface Runnable { /** * When an object implementing interface <code> Runnable </code> is used * to create a thread, starting the thread causes the object's * <code> run </code> method to be called in that separately executing * thread. * <p> * The general contract of the method <code> run </code> is that it may * take any action whatsoever. * * @see java.lang.Thread#run() */ public abstract void run () ; } 그렇기 때문에 람다식으로 표현이 가능한 것이다. 동기화 동기화는 동시에 같은자원의 접근을 제한하고자 할때 사용한다. 예를들어, 한 우물에서 물을 15번 길어야 하는 일을 해야할때 5명이서 3번만 하면 수고를 5배로 줄일수 있다. 그런데 우물은 하난데 동시에