Python 9

[ Python : 동시성과 병렬성 문법 배우기 ] 3. Concurrency CPU Bound, I/O Bound

1. Concurrency 논리적인 개념 CPU의 가용성을 극대화함. 싱글코어에 멀티스레드 패턴을 사용함. 일정량을 처리 후 다음 작업으로 넘김. 제어권을 주고받으며 작업하는 패턴 (vs Parallelism) 물리적. 멀티코어. 별개의 작업 처리 후 합침 2. Blocking I/O vs Non-Blocking I/O Blocking I/O : 시스템 콜 요청시 커널 I/O 작업 완료시까지 응답을 대기함. 제어권을 커널이 소유. 응답전까지 대기(block) -> 다음 작업 수행 X Non-Blocking I/O : 커널 I/O 작업 완료 여부 상관없이 즉시 응답. 주기적으로 시스템 콜을 통해서 I/O 작업 완료 여부 확인 Async : I/O 작업 완료 여부에 대한 Noty는 커널에서 유저로 전달됨 S..

Python 2021.08.01

[ Python : 동시성과 병렬성 문법 배우기 ] 2. Parallelism with Multiprocessing

1. Process vs Thread, Parallelism Parallelism : 완전히 동일한 시점에 태스크를 실행함. 다양한 파트로 나누어서 실행. (합 나누어서 구하고 취합하기) 하나의 코어가 아님. 멀티 프로세싱을 사용함 동시성 1개의 싱글코어에서 멀티쓰레드. 번갈아가며 처리. 컨텍스트 스위칭이 빠름 병렬성 멀티코어에서 각자의 일 끝내고 합침. 2. Join, is_alive 'multiprocess.Process' 모듈 사용 프로세스를 생성할 수 있음. start() : 실행 terminate() : 종료시키기 join() : 자식프로세스 끝나기 전까지 기다린 후 종료하기 is_alive() : 프로세스 상태 출력 3. Naming, Parallel Processing 생성자의 첫번째 필드에..

Python 2021.08.01

[ Python : 동시성과 병렬성 문법 배우기 ] 1. Multithreading

* 이 포스팅은 인프런강의 "동시성과 벙렬성 문법 배우기" 강의를 듣고 공부한 내용의 포스팅임 1. Multithreading Difference between Process and Thread 프로세스 : 운영체제에서 할당 받는 자원 단위 cpu동작 시간, 주소 공간(독립적)을 할당받음. 파이프, 파일, 소켓으로 프로세스간 통신 (context switching) 스레드 : 프로세스 내 실행단위. 프로세스 자원 사용. stack만 별도이며 나머지는 공유함. 메모리를 공유하며 한 스레드가 다른스레드에 영향을 끼침 -> 동기화가 필요함 멀티 스레드 : 여러 스레드로 구성 후 처리. 교착상태 발생가능 자원 소모가 감소고 통신 부담도 적어지지만 디버깅이 어려움 멀티 프로세스 : 문제 시 프로세스를 죽임. 캐시..

Python 2021.08.01

[Python 고급] 2. Meta class

* 이 포스팅은 인프런의 "파이썬 고급 (필수문법+오픈소스 패키지 배포)" 강의를 듣고 공부한 포스팅임 1. Meta class 모든 클래스를 칭함 클래스를 생성하는 과정에서 커스텀하는 과정의 역할을 수행함 (프레임워크 작성 시 필수) 동적 생성 type : 모든 클래스의 원형이며 커스텀 생성 함수임. 검증에 자주 사용됨 (엄격하게 class 생성 과정에 영향을 받음) 2. type 동적 클래스 생성 type( name, bases(상속을 받을 클래스), dict(인스턴스 메소드, 필드 등 값 전달) ) -> 클래스가 생성됨 3. 메타클래스 상속 metaclass 속성 사용하여 커스텀 메타 클래스를 생성함. 타입 상속 __new__() : 클래스 인스턴스를 생성함 초기화 __init__() : 인스턴스 ..

Python 2021.08.01

[Python 고급] 1. variable scope, context Manager

1. variable scope 전역변수 지역에서 읽을 수 있음 지역에서의 지역변수와 전역변수의 이름이 같을 때, 전역 변수 선택 시 'global' 키워드 붙여주기 nonlocal 키워드 (global 객체도 아니고 inner block의 변수도 아니므로) closer의 변수에 접근 시 선언식으로 키워드 사용하기 locals() 내부필드-메서드(지역전체) 를 dict로 리턴함 globals() 전역함수/변수를 dict로 리턴 키값에 접근해 값 변경가능 2. Context Manager 원하는 타이밍에 정확하게 리소스를 할당 및 반환 해줌 파일 I/O 시에 전용 클래스로 사용함. with 문과 같이 쓰임 __enter__(self) : with 구문에 진입하는 시점에 자동으로 호출되는 메소드 __exit..

Python 2021.07.31

[Python 중급] 2. 파이썬 병행성

* 병행성(Concurrency) : 한 컴퓨터가 여러일을 동시에 실행함. -> 내가 한 일들의 마지막 시점을 알아야 함. * 병렬성(Parallalism) : 여러 컴퓨터가 여러 일을 동시에 실행 1. 병행성 iterator : 반복가능한 객체를 생산함(iterable) __iter__ : 반복가능한 객체의 함수. 이터레이터가 생산됨. 반복시 iter()함수로 인자 1개씩 접근함 ( next() ) Generator 반복 가능한 객체를 리턴함. 코루틴과 연동하며 작은 메모리 조각을 뜻함. yield시 next()호출시에 리턴할 변수를 출력함. 다음 yield로 이동함 Coroutine 단일 싱글 스레드 스택 기반 비동기 작업 * 스레드(멀티스레드) OS에서 관리. CPU 코어에서 실시간, 시분할 비동기..

Python 2021.07.31

[Python 중급] 1. 파이썬 클래스, 시퀸스, 일급함수

* 이 포스팅은 인프런의 '파이썬 중급' 강의를 듣고 요약한 내용임 1. 파이썬 클래스 심화 클래스 & 메소드 클래스 기반의 개발은 객체지향 개발법으로 코드 재사용을 통하여 중복을 크게 줄일 수 있다. 데코레이터 클래스 메소드 : @classmethod 스태틱 메소드 : @staticmethod (인스턴스나 클래스로 호출이 가능함) 2. 파이썬 데이터 모델 매직 메소드 클래스 안에 정의 할 수 있는 특별한 method - 파이썬의 핵심 구조 built-In : 이미 만들어짐 모든 데이터 타입은 '클래스'임 __add__(), __str__(), __sub__(), __le__(), __ge__() 데이터 모델 추상화 데이터 모델 설계 - NamedTuple : Tuple + dictionary 키, 값을..

Python 2021.07.31

[Python 기초] 리스트 축약 표현

* 이 포스팅은 유튜브 "널널한 교수의 고급 파이썬" 강의를 듣고 요약한 포스팅임 1. 리스트 축약 반복 가능한 객체를 이용하여 쉽게 리스트를 생성하기 map 반복 가능한 객체에 원소들을 각각 탐색해서 함수의 반환값을 모아서 새로운 객체 형태로 반환해줌 a = [1.2, 2.5, 2.1, 5.5] a = list(map(int, a))​ # a => [1, 2, 2, 5] filter 특정 조건으로 걸러서 걸러진 요소들로 iterator 객체를 만들어 리턴해줌 filter(적용시킬 함수, 적용할 요소들) def check(n): return True if n // 10 >= 1 else False a = [1, 2, 10, 20] result = filter(check, a) print(list(resu..

Python 2021.07.30

[Python 기초] 파이썬 자료형

* 이 포스팅은 유튜브 "널널한 교수의 고급 파이썬" 강의를 듣고 요약한 포스팅임 1. 자료형과 참조변수 파이썬은 객체지향 언어로 참조변수를 통해 객체에 접근한다. 변수는 동적으로 참조하는 객체가 지정됨 객체당 고유하게 가지는 id값이 있음. 이는 주소와 관련이 있음 또한 하나의 객체에 여러 참조변수가 동시에 참조 가능 자료형 int, float, complex(복소수), str, list ... 리스트 mutable한 객체이며 원소는 모두 같은 자료형이여야 함. 리스트의 요소는 값을 참조하는 참조형임 mutable한 객체이므로 수정이 안됨. .append()시 추가된 원소를 가지는 새로운 객체를 가리키는것. 수정되는것이 아님. * 얕은 복사와 깊은 복사 단순참조로 할당 시, 데이터가 복사되지 않음. 참..

Python 2021.07.30