언어 55

(C# 7.2) Span<T>

이게 뭐고 왜 쓰나 Provides a type-safe and memory-safe representation of a contiguous region of arbitrary memory. 마이크로소프트 Docs에서 정의하는 Span의 기능이다. 사실 저게 뭔 말인가 싶지만 '배열에 대한 참조 뷰(View)를 제공하는 타입' 이라고 생각하면 된다. 그렇다 DB에서 자주 쓰이는 그 view이다. 그렇다면 이걸 왜 쓰는가? 힙 메모리 할당을 줄이기 위해 사용한다. Span 는 readonly ref struct이다. ref struct는 오로지 스택에만 생성이 가능한 구조체이다. 사용 예 1. 배열에 대한 View를 제공 { var arr = new int[] { 0, 1, 2, 3 }; var left ..

언어/C# 2022.08.07

아토믹으로 Lock-Free 자료구조 만들기

2022.07.03 - [언어/C++] - 아토믹 (Atomic, cpp17) 아토믹 (Atomic, cpp17) 왜 필요? #include #include #include using namespace std; void add (int & num) { for(int i=0;i threads; for (int i = 0; i < 4; ++i) threads.emplace_back(add, std::ref(num)); for (auto & thread : thre.. tsyang.tistory.com Thread-Safe한 자료구조가 필요하다고 하자. mutex등을 이용해서 자료구조로의 접근을 제한하는 방식은 느리다. 이전 글에서 다룬 atomic을 이용하여 스핀 락을 만든다면 mutex보다 더 빠른 락을 ..

언어/C++ 2022.07.10

C# async/await

개념 async/await 메서드는 비동기 함수라고도 불린다. 기존에 존재하던 Task의 장점을 살려 개발자가 좀 더 쉽게 비동기 작업을 수행할 수 있는 프로그래밍 만들고자 하여 탄생한 것이 바로 async/await 되시겠다. await 연산자는 피연산자가 나타내는 비동기 작업이 완료될 때까지 수행을 중지한다. 그리고 await연산자를 포함한 메서드에 async를 붙여 컴파일러가 해당 함수가 비동기 함수임을 알 수 있게 한다. static async void SomeMethod() { await Task.Run(() => { SomeHeavyWork(); //시간이 좀 걸리는 메서드 }); //Task가 끝난 뒤에야 아래 코드가 시작된다. Console.WriteLine("SomeHeavyWork En..

언어/C# 2022.06.12

스레드 동기화 - 기타 (이중 확인 락, 조건 변수, 컬렉션)

2022.05.29 - [언어/C#] - 복합 스레드 동기화 요소 복합 스레드 동기화 요소 2022.05.09 - [언어/C#] - 단순동기화3 - 커널 모드 동기화 단순동기화3 - 커널 모드 동기화 2022.05.06 - [언어/C#] - 단순동기화2 (유저 모드 동기화 요소) 커널 모드 동기화 요소 커널 모드 동기화 요소는 tsyang.tistory.com 이중 확인 락 기법 늦은 초기화(Lazy initialization)를 이용해 싱글톤 객체를 생성할 때, 다수의 스레드가 동시에 싱글톤 객체를 요청한다면 싱글톤 객체가 여러 번 생성될 수 있다. 따라서 스레드 동기화를 통해 싱글톤 객체가 단 한 번만 생성되도록 해줘야 하는데 이때 자주 사용되는 기법이 이중 확인 락(double-check locki..

언어/C# 2022.06.05

복합 스레드 동기화 요소

2022.05.09 - [언어/C#] - 단순동기화3 - 커널 모드 동기화 단순동기화3 - 커널 모드 동기화 2022.05.06 - [언어/C#] - 단순동기화2 (유저 모드 동기화 요소) 커널 모드 동기화 요소 커널 모드 동기화 요소는 유저 모드 동기화 요소에 비해서 상당히 느리다. 왜냐? 커널 모드 동기화 요소가 운영 tsyang.tistory.com 앞에서 유저모드 동기화, 커널 모드 동기화에 대해 다뤘다. 이 둘을 잘 섞은 복합 스레드 동기화 요소에 대해 알아보겠다. (제프리 리쳐가 만든 용어인듯?) 복합 스레드 동기화 요소 얘는 스레드들이 경쟁 상태가 아닐 때에는 유저 모드 동기화 요소를 써서 성능상의 장점을 취하고, 다수의 스레드가 경쟁 상태일 경우 커널 모드 동기화 요소를 써서 스피닝이 발생..

언어/C# 2022.05.29

단순동기화3 - 커널 모드 동기화

2022.05.06 - [언어/C#] - 단순동기화2 (유저 모드 동기화 요소) 커널 모드 동기화 요소 커널 모드 동기화 요소는 유저 모드 동기화 요소에 비해서 상당히 느리다. 왜냐? 커널 모드 동기화 요소가 운영체제에게 스레드 간의 동기화를 요청해서 그렇다. 또한 각각의 메서드들은 커널 객체를 이용하게 되고 이로 인해 스레드가 관리 코드 -> 네이티브 유저 모드 -> 네이티브 커널 모드 (돌아올 때도 역순으로 반복함) 위와 같은 전환을 일으켜 CPU 시간을 엄청나게 소비하기 때문이기도 하다. 그래도 커널 모드 동기화 요소를 쓰는 이유가 있다. 리소스에 대한 경쟁 상태를 확인할 수 있다. 스레드가 CPU를 낭비하지 않도록 한다. 네이티브 스레드와 관리 스레드 사이에서도 동기화를 할 수 있다. 동일 컴퓨터..

언어/C# 2022.05.09

단순동기화2 - 유저 모드 동기화

2022.05.01 - [언어/C#] - CLR 단순 동기화1 CLR 단순 동기화1 스레드 동기화 스레드 동기화는 일반적으로 다수의 스레드가 공유 데이터에 '동시에' 접근하는 경우에도 데이터가 손상되는 것을 막기 위해서 사용된다. 그러나 스레드 동기화는 많은 문제를 tsyang.tistory.com 유저 모드 동기화 요소 CLR은 bool, byte, short, int, float, 참조 타입의 변수에 대해서는 원자적(atomic)으로 값을 읽고 쓸 수 있음을 보장한다. 이게 뭔말이냐면 int x = 0; x = 0x01234567; x 변수가 0x00000000에서 0x01234567로 한 번에 번경된다는 말이다. 즉, 변경 중인 상태의 값을 얻어올 가능성이 없다는 말이다. 엥.. 그럼 아닌 경우도 ..

언어/C# 2022.05.06

CLR 단순 동기화1

스레드 동기화 스레드 동기화는 일반적으로 다수의 스레드가 공유 데이터에 '동시에' 접근하는 경우에도 데이터가 손상되는 것을 막기 위해서 사용된다. 그러나 스레드 동기화는 많은 문제를 가지고 있다. 우선 오류를 발생시킬 가능성이 높다. 왜냐? 코드를 작성할 때 여러 스레드에서 동시에 접근할 수 있는 데이터들을 모두 확인한 후, 스레드 동기화 락을 데이터 접근 부분에 모두 적용해야 한다. 만약 락을 한 군데라도 빠트리면 오류가 발생한다. 테스트도 매우 힘들다. 유일한 테스트는 그냥 여러번 실행시켜 본뒤 문제가 발생하기 않길 비는 수밖에... 그리고 이런 테스트는 여러 개의 CPU를 가진 컴퓨터에서 해보는게 좋다. 왜냐? 그래야 여러 개의 스레드가 동시에 리소스에 접근할 가능성이 높기 때문이다. 성능이 떨어지..

언어/C# 2022.05.01

CLR 스레딩3 - 태스크(Task)

2022.04.17 - [언어/C#] - CLR 스레드 단순 계산 작업 태스크 앞선 글에서 계산 중심의 비동기 작업을 주행하기 위해 ThreadPool 의 QueueUserWorkItem을 호출하는 방식을 소개헀다. 그러나 이 방법은 작업 완료 시점과 작업 수행의 결과를 얻을 수 있는 방법을 제공하지 않고 있다는 한계가 있다. 그래서 생긴게 태스크(tasks) 라는 개념이다. //ThreadPool을 이용한 방식 ThreadPool.QueueUserWorkItem(obj => Sum(1000)); //Task를 이용한 방식1 var task = new Task(() => Sum(1000)); task.Start(); //Task를 이용한 방식2 Task.Run(() => Sum(1000)); 태스크의 결..

언어/C# 2022.04.24