참고 https://learnyousomeerlang.com/starting-out#the-shell Erlang Shell에서 실행 가능한 명령어 2> help(). ** shell internal commands ** b() -- display all variable bindings e(N) -- repeat the expression in query f() -- forget all variable bindings f(X) -- forget the binding of variable X ... erlang 쉘에서는 여러 명령어를 실행할 수 있다. 어떤 명령어를 실행할 수 있는지는 help().를 이용하면 된다. 예를 들어서 erlang 쉘에서 memory()를 실행하면 다음 결과를 확인할 수 있다. ..
요약 리스트 컴프리헨션은 람다식을 사용하지 않기 때문에 람다식을 사용하는 map, filter 대비 가독성이 좋음. 리스트 컴프리헨션을 이용하면 조건식을 이용해 간단히 특정 원소를 스킵할 수 있음. 그러나 map을 사용할 때는 filter 함수의 도움을 받아야 함. 결론은 map, filter를 사용하면 람다 함수를 사용해야 한다. 그런데 람다 함수는 이름을 가지지 않으므로 람다 함수가 무슨 일을 하는지 이해하기 어렵다. 따라서 가독성이 떨어지는 코드가 된다. Item 27. map과 filter 대신 컴프리헨션을 사용하라 # 짝수를 제곱한 값 구하기 a = [1, 2, 3, 4, 5, 6, 7, 8] # 컴프리헨션 이용 even_squares = [x ** 2 for x in a if x % 2 == ..
요약 데코레이터를 사용했을 때, 데코레이터 함수는 원본 함수의 정보와 Docs에 대한 정보를 더 이상 반환하지 않는다. 데코레이터를 이렇게 사용하면 디버깅 하는 과정에서 잘못 동작할 수 있다. 이런 부분을 해결하기 위해 functools의 wraps 데코레이터를 사용해주면 된다. Item 26. functools.wrap을 사용해 함수 데코레이터를 정의하라 # 데코레이터를 사용하면, 기존 함수의 이름과 __Docs__는 없어짐. # 디버깅 시에 문제가 발생할 수 있음. def deco(func): def wrapper_func(*args, **kwargs): print('here') return func(*args, **kwargs) return wrapper_func @deco def hello(): ..
요약 위치 기반 인자를 의도치 않게 키워드 인자로 사용하는 경우, 함수 호출부와 강하게 결합함. 이 때, 위치 기반 인자의 이름 변화가 이 함수를 호출하는 쪽에도 의도치 않게 영향을 줄 수 있음. 위치 기반 인자, 키워드 기반 인자를 강제할 수 있음. 함수 호출부의 / 앞에 있는 인자들은 위치 기반 인자로만 사용됨. 함수 호출부의 * 뒤에 있는 인자들은 키워드 인자로만 사용됨. 함수 호출부의 /와 * 사이에 있는 인자들은 위치 + 키워드 인자로 둘다 사용될 수 있음. 함수 호출부에서 키워드 기반 인자를 사용하면, 인자의 뜻을 이해하기 쉬워 가독성이 좋아짐. 함수 내에서 옵션으로 사용하는 변수는 키워드 기반 인자로 사용하는 것이 좋음. 예를 들면, 함수 호출 시 에러를 던지고 말지를 결정한다는 형식으로....
요약 클로저는 자유변수를 참조하는 함수다. 파이썬의 변수 참조는 다음 순서로 이루어진다 함수가 선언된 내부 영역 함수를 둘러싼 영역 모듈 빌트인 영역(len, str 등이 선언된) 변수 참조 순서를 고려해서 필요한 경우 nonlocal 키워드를 이용해 자유변수임을 알려줘야한다. 그렇지 않으면 기대하지 않은 방식으로 동작한다. nonlocal 키워드는 가급적이면 적게 써야한다. nonlocal 키워드 선언 부분과 변수가 실제로 사용되는 부분이 멀어지면 이해하기 어려운 코드가 되기 때문이다. 이펙티브 파이썬 Item 21. 변수 영역과 클로저의 상호작용 방식을 이해하라 # helper는 클로저가 됨. def sort_priority(values, group): def helper(x): if x in gro..