• 회원가입
  • 로그인
  • 구글아이디로 로그인

[PHP-생코] PHP 7강 - 접근제어자 = 속성의 가시성(property visibility) ※ 캡슐화(encapsulation)

1,040  


접근 제어자 1 - 개념

 

접근제어자(access modifier) = 속성의 가시성(property visibility) 

캡슐화 달성 수단 중 하나.

 

캡슐화(encapsulation)

객체 사용자에게 필요한 정보/기능만 노출시켜서, 편의성 및 안정성 높이는 작업.

 

 

 

 

접근 제어자 2 (private vs public)


<?php

class MyFileObject{

  private $filename;

  function __construct($fname){

    $this->filename = $fname;

    if(!file_exists($this->filename)){

      die('There is no file '.$this->filename);

    }

  }

  function isFile(){

    return is_file($this->filename);

  }

}

$file = new MyFileObject('data.txt');

// $file = new MyFileObject();

// $file->filename = 'data.txt';

var_dump($file->isFile());

var_dump($file->filename);

?>

 

 

 

접근 제어자 3 - (private vs public)

 

<?php

class Person{

  private $name;

  function sayHi(){

    print("Hi, I'm {$this->name}.");

  }

  function setName($_name){

    if(empty($_name)){

      die('I need name');

    }

    $this->name = $_name;

  }

  function getName(){

    return $this->name;

  }

}

$egoing = new Person();

$egoing->setName('egoing');

$egoing->sayHi();

print($egoing->getName());

?>

 


접근 제어자 3 (method visibility)

 

<?php

class Person{

  private $name;

  public function sayHi(){

    print("Hi, I'm {$this->name}.");

  }

  public function setName($_name){

    $this->ifEmptyDie($_name);

    $this->name = $_name;

  }

  public function getName(){

    return $this->name;

  }

  private function ifEmptyDie($value){

    if(empty($value)){

      die('I need name');

    }

  }

}

$egoing = new Person();

$egoing->setName('egoing');

$egoing->sayHi();

print($egoing->getName());

?>

 

https://opentutorials.org/module/6/15730

 

PS.

 

Visibility 

https://www.php.net/manual/en/language.oop5.visibility.php

 

접근제어자

https://homzzang.com/b/php-1065

 

 


분류 제목
SQL-생코 SQL 43강 - mysql 리플리케이션 mmm 사용 4 - 2
SQL-생코 SQL 42강 - mysql 리플리케이션 (mmm소개) 4-1
SQL-생코 SQL 41강 - mysql 리플리케이션(동기화 확인) 5
SQL-생코 SQL 40강 - mysql 리플리케이션(구축) 3-3
SQL-생코 SQL 39강 - mysql 리플리케이션(구축) 3-2
SQL-생코 SQL 38강 - mysql 리플리케이션(구축) 3-1 ★ - 마스터에서 압축해 슬레이브로 전송
SQL-생코 SQL 37강 - mysql 리플리케이션(준비) 2-2 - SSH 접속법
SQL-생코 SQL 36강 - mysql 리플리케이션(준비) 2 - 가상머신으로 마스터 서버, 슬레이브 서버 만들기
SQL-생코 SQL 35강 - mysql 리플리케이션
SQL-생코 SQL 34강 - mysql 프로그래밍과 연동-window
SQL-생코 SQL 33강 - mysql 프로그래밍과 연동 ★★★★★
SQL-생코 SQL 32강 - mysql 사용자관리3 - phpmyadmin
SQL-생코 SQL 31강 - mysql 사용자관리2
SQL-생코 SQL 30강 - mysql 사용자관리
SQL-생코 SQL 29강 - mysql 데이터관리-조회(join) ★★★★★★★★★★
SQL-생코 SQL 28강 - mysql 데이터관리-조회(index) ★★★★★
SQL-생코 SQL 27강 - mysql 데이터관리-조회(order)-phpmyadmin
SQL-생코 SQL 26강 - mysql 데이터관리-조회(order)
SQL-생코 SQL 25강 - mysql 데이터관리-조회(group)
SQL-생코 SQL 24강 - mysql 데이터관리-조회(select)-phpmyadmin
28/35
목록
찾아주셔서 감사합니다. Since 2012