도서 소개
모던 C++로 배우는 동시성 프로그래밍
제이펍
2018. 8. 3. 16:44
그동안 읽어주신 분들께 감사드립니다. 이 책은 현재 절판되었습니다.
C++ 프로그래머라면 반드시 알아야 할 동시성의 모든 것!
C++ 동시성 프로그래밍을 마스터할 수 있는 실용적 안내서!
[강컴] [교보문고] [도서11번가] [반디앤루니스] [알라딘] [예스이십사] [인터파크]
출판사 제이펍
원출판사 Rainer Grimm
원서명 Concurrency with Modern C++(원서 ISBN: 없음)
저자명 라이너 그림
역자명 배장열
출판일 2018년 8월 6일
페이지 316쪽
시리즈 (없음)
판 형 (188*245*16)
제 본 무선(soft cover)
정 가 25,000원
ISBN 979-11-88621-30-9 (93000)
키워드 C++ / Concurrency / atomic / 멀티스레딩 / 병렬 알고리즘
분야 프로그래밍 / C++ / 병렬 프로그래밍
C++11과 C++14은 동시적이고 병렬적인 프로그램을 만들기 위한 기본 빌딩 블록을 갖췄다.C++17에서는 표준 템플릿 라이브러리(STL)의 병렬 알고리즘을 지원한다. 다시 말해, STL 기반 알고리즘은 대부분 순차적으로나 병렬적으로 또는 벡터화 방식으로 실행될 수 있다.C++의 동시성 이야기는 현재 진행형이다. C++20에는 확장 퓨처와 코루틴, 트랜잭션 등이 담길 것으로 예상된다.
더보기PART II 본론 _ 13CHAPTER 2 메모리 모델 15계약 16 기반 17 도전 18원자계 19 꼼꼼한 메모리 모델 vs 허술한 메모리 모델 19 원자계 플래그 22 클래스 템플릿 std::atomic 27 사용자 정의 원자계 34 원자계 연산들 35 원자계 자유 함수들 36동기화 및 순서상 제약 조건 39 C++의 여섯 가지 메모리 모델 39 시퀀스 일관성 41 acquire-release 시맨틱 44 std::memory_order_consume 53 편안한 시맨틱 57담장 60 메모리 장벽으로서의 담장 60 세 가지 담장 60 acquire 담장과 release 담장 63 원자계 변수의 동기화와 담장의 동기화 65 CHAPTER 3 멀티스레딩 71스레드 72 생성 72 라이프사이클 73 인수 76 메서드 80공유 데이터 83 뮤텍스 85 잠김 90 스레드 안전한 초기화 100스레드 로컬 데이터 106조건 변수 108 wait 작업 흐름 110 사라진 깨우기와 가짜 깨우기 112태스크 112 스레드와 태스크 113 std::async 115 std::packaged_task 120 std::promise와 std::future 124 CHAPTER 4 사례 연구 135벡터의 합 계산하기 136 벡터의 싱글스레딩 덧셈 137 공유 변수의 멀티스레딩 합 143 스레드 로컬 합 148 벡터의 합: 결론 157싱글턴의 스레드 안전한 초기화 158 잠김 패턴의 이중 확인 159 성능 측정 160 스레드 안전한 마이어스 싱글턴 163 std::once_flag와 결합된 std::call_once 166 원자계 167 스레드 안전한 싱글턴 구현의 성능 수치들 170CppMem 연속 최적화 171 CppMem 개요 172 CppMem: 비원자계 변수 176 CppMem: 잠김 180 CppMem: 시퀀스 일관성 원자계 182 CppMem: acquire-release 시맨틱 원자계 187 CppMem: 비원자계가 적용된 원자계 190 CppMem: 편안한 시맨틱 원자계 192결론 194 CHAPTER 5 표준 템플릿 라이브러리의 병렬 알고리즘 195실행 정책 196알고리즘 198새 알고리즘들 199 함수형 유산 203 CHAPTER 6 미래: C++20 205원자계 스마트 포인터 206 스레드 안전한 단일 연결 리스트 207확장 퓨처 208 std::future 208 std::async, std::packaged_task, std::promise 210 새 퓨처 생성하기 210래치와 장벽 213 std::latch 214 std::barrier 214 std::flex_barrier 216코루틴 217 제너레이터 함수 218 세부 내용 221트랜잭션 메모리 223 ACI(D) 224 동기화 블록과 원자계 블록 224 transaction_safe 코드와 transaction_unsafe 코드 228태스크 블록 229 fork와 join 229 define_task_block과 define_task_block_restore_thread 231 인터페이스 231 스케줄러 232 PART III 심화 _ 233CHAPTER 7 도전 235ABA 236 비유 236 비임계 ABA 237 잠김 없는 데이터 구조 237 ABA 문제 238 해결책 239블로킹 문제 241프로그램 불변식 깨기 243데이터 경쟁 244가짜 공유 246변수의 라이프사이클 문제 246움직이는 스레드 247교착상태 249경쟁 상태 250 CHAPTER 8 베스트 프랙티스 251개괄 252 코드 리뷰 252 변형 가능한 데이터의 데이터 공유를 최소화하라 252 대기를 최소화하라 253 변형 불가능한 데이터를 먼저 사용하라 253 올바른 추상화를 찾아라 253 정적 코드 분석 도구를 사용하라 254 동적 강화 도구를 사용하라 254메모리 모델 255 동기화에 volatile을 사용하지 마라 255 잠김 없는 프로그램을 만들지 마라 256 잠김 없는 프로그램이 불가피할 때는 잘 정립된 패턴을 사용하라 256 자신만의 추상화를 만들지 말고 언어가 제공하는 보장을 사용하라 256멀티스레딩 257 스레드 257 데이터 공유 259 조건 변수 262 프로미스와 퓨처 265 CHAPTER 9 time 라이브러리 267시점과 기간, 클록의 상호작용 268시점 269 시점에서 캘린더 시간까지 269 유효한 시간 범위를 넘어 271기간 272 계산 274클록 276 정확도와 고정성 277 에포크 279잠자기와 기다리기 281 관습 281 다양한 기다리기 전략 282 CHAPTER 10 용어 287 찾아보기 295