먼저, 프로그램을 짤 때 왜 배열 변수라는 것이 필요한지 그 점에 관해 설명해드리겠습니다.
예를 들어 100명의 학생의 영어 성적의 합계를 구하는 프로그램을 짠다고 해봅시다.
만일, 배열 변수없이 프로그램을 짠다면 다음과 같을 것입니다.
<?
$score_1 = 50;
$score_2 = 70;
.
.
.
$score_99 = 80;
$score_100 = 60;
$sum = $score_1 + $score_2 + ... + $score_99 + $score_100;
?>
위와 같이 배열 변수를 사용하지 않으면 서로 다른 100개의 변수명에 성적을 넣은 후 $sum 변수에 100명의 성적의 합계를 계산한 값을 넣기 위해서 서로 다른 변수명을 가진 100개의 변수들을 일일이 적어주어야 할 것입니다.
그 결과, $sum 에 합계를 계산한 값을 넣는 코드가 너무 길어져 비효율적인 프로그램이 될 것입니다.
하지만, 배열 변수를 도입해서 위와 같은 프로그램을 짠다면 다음과 같습니다.
<?
$score[0] = 50;
$score[1] = 70;
.
.
.
$score[98] = 80;
$score[99] = 60;
for($count = 0; $count < 100; $count++) {
$sum = $sum + $score[$count];
}
?>
위와 같이 배열 변수를 사용하면 100명의 성적을 $score 라는 동일한 변수명에 넣어준 다음 $sum 변수에 성적의 합계를 계산한 값을 넣기 위해서 $score 라는 하나의 동일한 변수명만을 사용한 것을 볼 수 있습니다.
따라서, 배열 변수를 사용하면 위 예제처럼 $sum 에 합계를 계산한 값을 넣는 코드가 배열을 사용하지 않은 프로그램에 비해 훨씬 코드 길이를 줄일 수 있고 효율적으로 프로그램을 짤 수 있습니다.
그리고, 배열 변수에서 알아두어야 할 점은 동일한 변수명에 할당되어 있는 각각의 값들을 구별해주기 위해서 인덱스라는 것을 사용합니다. 바로 위 예제에서 $score 다음에 보이는 [0], [1] 등이 그 $score 라는 배열 변수의 인덱스가 됩니다.(인덱스 번호는 1 이 아니라 0 부터 시작합니다.)
그래서, 위 예제는 $score 라는 배열 변수의 인덱스 값을 for 반복문을 사용해서 0부터 99까지 변화시켜주어 $sum 에 차례차례 100명의 성적을 계속 누적시키게 됩니다.
(for 반복문에 대한 설명은 나중에 해드리겠습니다.)
다시 한번 오늘 배운 배열 변수에 관해 정리하자면
배열 변수란 동일한 자료형을 가지는 데이터를 효율적으로 다루기 위해서 사용되는 변수로 하나의 동일한 변수명을 가지며 각각의 값들은 인덱스로 구별됩니다.
그리고 PHP에서 배열 변수를 사용하는 방법은 동일한 변수명에 인덱스번호를 붙여주는 형태로 아래와 같습니다.
<?
$score[0] = 50;
$score[1] = 70;
$score[2] = 60;
.
.
.
?>
오늘 배열 변수에 관해 설명해드렸는데, 제가 제시한 예제가 적절하지 않을 수도 있어서 혹시 이해하시는데 어려움이 있을지도 모르겠네요.
만일, 위의 내용이 이해가 되지 않더라도 지금 걱정하지 않으셔도 됩니다.
게시글 목록
| 번호 | 제목 |
|---|---|
| 12357 | |
| 12356 |
MySQL
MySQL php함수 정리 입니다.
|
| 12355 |
MySQL
MySQL php오류 정리 입니다.
|
| 12354 |
MySQL
연산자 관련함수 정리 입니다.
|
| 12353 |
JavaScript
폼 유효성검사해주는 자바스트립트 라이브러리
|
| 20387 | |
| 12352 |
MySQL
수학 관련함수 정리 입니다.
|
| 12351 |
MySQL
문자열 관련함수 정리 입니다.
|
| 12350 |
MySQL
날짜 관련 함수 정리 입니다.
|
| 12349 | |
| 12348 |
jQuery
Ajax 화면 전환 시 애니메이션 효과
|
| 12347 |
MySQL
Query의 기본사용 정리 입니다.
|
| 12346 | |
| 12345 |
MySQL
콘솔 기본명령어 정리 입니다
|
| 12344 |
PHP
암호화 SHA-256
|
| 12343 |
MySQL
mysql 인덱싱 하는 방법 입니다.
|
| 12342 |
MySQL
MySQL 덤프방법(dump) 입니다.
|
| 12341 |
MySQL
여러데이터베이스 사용하는 방법 입니다.
|
| 12340 |
PHP
이미지에 글자쓰기
|
| 12339 |
MySQL
백업&복구(전체/부분/테이블) 하기 입니다.
|
| 12338 |
MySQL
db sql문 정리 입니다.
|
| 12337 | |
| 12336 |
JavaScript
라디오버튼, 체크박스 테두리 없애기 입니다.
|
| 12335 |
JavaScript
현재 페이지 저장하기 입니다.
|
| 12334 |
JavaScript
프린트 출력 자바스크립트 입니다.
|
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기