기본 콘텐츠로 건너뛰기

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...

(java) 크롬에서 쿠키 삭제 안되는 경우

  java에서 쿠키 삭제하는 방법은 똑같은 이름의 쿠키를 만들고 업데이트 하는 방식이다.  이때 maxAge를 '0' 으로 설정한다.  그래서 아래처럼 코딩한결과  크롬을 제외한 나머지 브라우저에서는 전부 쿠키가 삭제가 되었으나 크롬만 삭제가 되지 않았다.  문제의코드 Cookie cookie = new Cookie(name , null ) ; cookie.setHttpOnly( false ) ; cookie.setMaxAge( 0 ) ; cookie.setPath( "/" ) ; cookie.setDomain( "test.co.kr" ) ; 결론만 얘기하면  Secure 설정을 ture로 추가해서 해결했다.  https, ssl 기반에서만 주고받을 수 있게된다.  public void setSecure ( boolean flag) { secure = flag ; } /** * Returns <code> true </code> if the browser is sending cookies only over a * secure protocol, or <code> false </code> if the browser can send cookies * using any protocol. * * @return <code> true </code> if the browser uses a secure protocol; * otherwise, <code> true </code> * @see #setSecure */ 원인은 이사이트의 쿠키설정중 samesite가 'none' 으로 설정되어있었다.  samesite가 none인 경우에는 반드시 secure 옵션을 같이 넣어줘야 크롬에서 정상동작한다. (chrome 80 버전 업데이트 이슈) 웹서버에서 변경하고 싶으면 nginx.c...