반응형

# 백업

  • 소스 및 자료를 각종 재해(해킹, 소프트웨어 버그 및 오동작 등)에 대비하여 시스템을 회복 가능한 상태로 만들기 위해 준비하는 작업을 의미한다.

 

# 현행시스템 파악

  • 현행 시스템이 어떠한 하위 시스템으로 구성되어 있는지, 제공 가능한 기능 및 연계 정보는 무엇인지, 어떤 기술 요소를 사용하는지 파악하는 활동이다.

 

# 소프트웨어 아키텍처

  • 여러 소프트웨어 구성요소와 구성요소가 가진 특성 중 외부에 드러나는 특성, 그리고 구성요소 간의 관계를 표현하는 시스템의 구조나 구조체를 의미한다.

 

# 소프트웨어 아키텍처 프레임워크

  • 소프트웨어 집약적인 시스템에서 아키텍처가 표현해야 하는 내용과 이들 간의 관계를 제공하는 아키텍처 기술 표준이다.
반응형
반응형

# 루프 제어문

1. break

  • break는 반복문이나 switch문을 중간에 탈출하기 위해 사용하는 명령어이다.
1. C언어 코드
#include <stdio.h>

void main() {

	int i = 0
    
    while(1) {
    	printf("%d\n", i);
    	i++;
        
        if( i >= 5 ) {
        	break;
        }
    }

}

// 출력 결과 : 0 1 2 3 4 5

- 변수 i에 0을 저장
- 조건이 1이라는 것은 항상 참이므로 무한 반복된다.
- i++로 인해 i의 값이 1씩 증가된다.
- i가 5보다 크거나 같을 경우, 해당 반복문을 탈출하게 된다.


2. C++ 코드
#include <iostream>

void main() {

	int i = 0;
    while(1) {
    	std:cout << "i << std::endl;
        i++;
        
        if ( i >= 5 ) {
        	break;
        }
    }
    
    
}

// 출력 결과 : 0 1 2 3 4 5

- 변수 i에 0을 저장
- 조건이 1이라는 것은 항상 참이므로 무한 반복된다.
- i++로 인해 i의 값이 1씩 증가된다.
- i가 5보다 크거나 같을 경우, 해당 반복문을 탈출하게 된다.


3. 자바 코드
public static void main(String[] args) {
	
    int i = 0;
    while(true) {
    	System.out.println(i);
        i++;
        
        if( i >= 5 ) {
        	break;
        }
    }
    
}

// 출력 결과 : 0 1 2 3 4 5

- 변수 i에 0을 저장
- 조건이 true 이므로 무한 반복된다.
- i++로 인해 i의 값이 1씩 증가된다.
- i가 5보다 크거나 같을 경우, 해당 반복문을 탈출하게 된다.


4. 파이썬 코드
	i = 0
	
    while True:
    	print(i)
        i = i + 1
        if i >= 5:
        	break;

// 출력 결과 : 0 1 2 3 4 5

- 변수 i에 0을 저장
- 조건이 1이라는 것은 항상 참이므로 무한 반복된다.
- i++로 인해 i의 값이 1씩 증가된다.
- i가 5보다 크거나 같을 경우, 해당 반복문을 탈출하게 된다.

 

2. continue

  • continue는 반복문에서 다음 반복으로 넘어갈 수 있도록 하는 명령어.
1. C언어 코드
#include <stdio.h>

void main() {

	int i;
    
    for ( i = 0; i < 100; i++ ) {
    	if ( i % 3 == 0 ) {
        	continue;
            printf("%d\n", i);
        }
    }
}

// 출력 결과 : 1 2 4 5 7 8 .... 98

- 변수 i
- i는 0 ~ 99 반복
- i가 3으로 나눠 떨어질 경우 다음 반복을 수행한다.


2. C++ 코드
#include <iostream>

void main() {

	int i;
    
    for ( i = 0; i < 100; i++ ) {
    	if ( i % 3 == 0 ) {
        	continue;
            std::cout << i << std::endl;
        }
    }
    
}

// 출력 결과 : 1 2 4 5 7 8 .... 98

- 변수 i
- i는 0 ~ 99 반복
- i가 3으로 나눠 떨어질 경우 다음 반복을 수행한다.


3. 자바 코드
public static void main(String[] args) {
	
    int i;
    
    for ( i = 0; i < 100; i++ ) {
    	if ( i % 3 == 0 ) {
        	continue;
            System.out.println(i);
        }
    }
    
}

// 출력 결과 : 1 2 4 5 7 8 .... 98

- 변수 i
- i는 0 ~ 99 반복
- i가 3으로 나눠 떨어질 경우 다음 반복을 수행한다.


4. 파이썬 코드
	
    for i in range(0, 100)
    if i % 3 == 0:
    	continue
        print(i)

// 출력 결과 : 1 2 4 5 7 8 .... 98

- 변수 i
- i는 0 ~ 99 반복
- i가 3으로 나눠 떨어질 경우 다음 반복을 수행한다.

 

# 배열 / 리스트

1. 배열/리스트란

  • 번호(index)와 번호에 대응하는 데이터들로 이루어진 자료 구조를 의미한다.

 

2. 배열

  • C, C++, 자바에서는 배열을 통해 같은 데이터 타입을 저장한다.
  • 파이썬은 리스트를 통해 같거나 다른 데이터 타입을 저장한다.
1. C언어 코드
#include <stdio.h>

void main() {

	int i;
    int sum = 0;
    int a[5] = {4, 2, 1, 7, 10};
    
    for ( i = 0; i < 5; i++ ) {
    	sum += a[i];
    }
    
    printf("%d\n", sum);
    
}

// 출력 결과 : 24

- 변수 i, 합계를 담을 변수 sum
- 5개의 요소를 가진 배열 a


2. C++ 코드
#include <iostream>

void main() {

	int i;
    int sum = 0;
    int a[5] = {4, 2, 1, 7, 10};
    
    for ( i = 0; i < 5; i++ ) {
    	sum += a[i];
    }
    
    std::cout << sum << std::endl;
    
}

// 출력 결과 : 24

- 변수 i, 합계를 담을 변수 sum
- 5개의 요소를 가진 배열 a


3. 자바 코드
public static void main(String[] args) {
	
    int i;
   	int sum = 0;
    int a[5] = {4, 2, 1, 7, 10};
    
    for ( i = 0; i < 5; i++ ) {
    	sum += a[i];
    }
    
    System.out.println(sum);    
}

// 출력 결과 : 24

- 변수 i, 합계를 담을 변수 sum
- 5개의 요소를 가진 배열 a


4. 파이썬 코드
	
    sum = 0
    a = [4, 2, 1, 7, 10]
    
    for i in range(0, 5):
    	sum += a[i]
        
    print(sum)

// 출력 결과 : 24

- 변수 i, 합계를 담을 변수 sum
- 5개의 요소를 가진 리스트 a

 

3. 2차원 배열

  • 배열을 다차원 형태로 구성할 수 있다.
1. C언어 코드
#include <stdio.h>

void main() {

	int i, j;
    int a[2][2] = {{1, 2} ,{3, 4}};
    int j[2][2] = {{1, 2} ,{3, 4}};
    int c[2][2];
    
    for ( i = 0; i < 2; i++ ) {
    	for ( j = 0; j < 2; j++ ) {
        	c[i][j] = a[i][j] + b[i][j];
        }
    }
    
    for ( i = 0; i < 2; i++ ) {
    	for ( j = 0; j < 2; j++ ) {
        	printf("%d\n", c[i][j]);
        }
    }
    
}

// 출력 결과 : [2, 4, 6, 8]

- 2차원 배열 a, b
- c는 a, b의 같은 인덱스에 있는 값을 더한 후 저장


2. C++ 코드
#include <iostream>

void main() {

	int i, j;
    int a[2][2] = {{1, 2} ,{3, 4}};
    int j[2][2] = {{1, 2} ,{3, 4}};
    int c[2][2];
    
    for ( i = 0; i < 2; i++ ) {
    	for ( j = 0; j < 2; j++ ) {
        	c[i][j] = a[i][j] + b[i][j];
        }
    }
    
    for ( i = 0; i < 2; i++ ) {
    	for ( j = 0; j < 2; j++ ) {
        	std::cout << c[i][j] << std::endl;
        }
    }
    
}

// 출력 결과 : [2, 4, 6, 8]

- 2차원 배열 a, b
- c는 a, b의 같은 인덱스에 있는 값을 더한 후 저장


3. 자바 코드
public static void main(String[] args) {
	
    int i, j;
    int a[][] = {{1, 2} ,{3, 4}};
    int j[][] = {{1, 2} ,{3, 4}};
    int [][]c = new int[2][2];
    
    for ( i = 0; i < 2; i++ ) {
    	for ( j = 0; j < 2; j++ ) {
        	c[i][j] = a[i][j] + b[i][j];
        }
    }
    
    for ( i = 0; i < 2; i++ ) {
    	for ( j = 0; j < 2; j++ ) {
        	System.out.println(c[i][j]);
        }
    }
    
}

// 출력 결과 : [2, 4, 6, 8]

- 2차원 배열 a, b
- c는 a, b의 같은 인덱스에 있는 값을 더한 후 저장


4. 파이썬 코드
	

    a = {{1, 2} ,{3, 4}}
    b = {{1, 2} ,{3, 4}}
    c = []
    
    for i in range(0, 2):
    	for j in range(0, 2):
        	c.append(a[i][j] + b[i][j])
    
    print(c)

// 출력 결과 : [2, 4, 6, 8]

- 2차원 배열 a, b
- c는 a, b의 같은 인덱스에 있는 값을 더한 후 저장
반응형
반응형

# 체크 인

  • 저장소에 새로운 버전의 파일로 갱신하는 행위를 의미한다.

 

# 체크 아웃

  • 버전 등록 관리에서 저장소의 파일을 받는 행위를 의미한다.

 

# 공유 폴더 방식

  • 소프트웨어 버전관리 유형 중 하나로 개발완료 파일을 매일 약속된 위치의 공유폴더에 복사하는 방식을 의미한다.

 

# CVS

  • 서버와 클라이언트로 구성되어 다수의 인원이 동시에 범용적인 운영체제로 접근 가능하여 버전 관리가 가능한 형상 관리 도구이다.

 

# SVN

  • 하나의 서버에서 소스를 쉽고 유용하게 관리할 수 있게 도와주는 형상 관리 도구이다.

 

# GIT

  • 속도에 중점을 둔 분산형 버전 관리 시스템을 의미한다.
  • 대평 프로젝트에서 유용하고 효과적인 형상관리 도구이다.
반응형
반응형

# Secure DB

  • 커널 암호화 방식으로 데이터베이스 파일을 직접 암호화 하고, 접근 제어와 감사기록 기능이 추가된 데이터베이스 보안 강화 기술이다.

 

# SSO

  • 한 번의 시스템 인증을 통해 여러 정보시스템에 재인증 절차 없이 접근할 수 있는 통합 로그인 기술이다.

 

# 제품 소프트웨어 매뉴얼

  • 제품 소프트웨어 개발단계부터 적용한 기준이나 패키징 이후 설치 및 사용자 측면의 주요 내용 등을 기록한 문서이다.

 

# 제품 소프트웨어 설치 매뉴얼

  • 사용자가 제품을 구매한 후 최초 설치 시 참조하는 매뉴얼을 의미한다.

 

# 제품 소프트웨어 배포본

  • 개발된 컴포넌트 또는 패키지에 대해 제품화하고 배포 정보를 포함한 문서를 의미한다.

 

# 제품 소프트웨어 형상관리

  • 소프트웨어의 변경 사항을 체계적으로 추적하고 통제하는 관리 기법을 의미한다.
반응형

+ Recent posts