開発環境
- OS X Mavericks - Apple(OS)
- Emacs (CUI)、BBEdit - Bare Bones Software, Inc. (GUI) (Text Editor)
- C++ (プログラミング言語)
- g++(コンパイラ)
C++実践プログラミング (スティーブ オウアルライン (著)、Steve Oualline (原著)、Steve Oualline(原著)、望月 康司(翻訳)、クイープ(翻訳) 、オライリー・ジャパン)のⅢ部(高度な型とクラス)の14章(クラス - その2)、14.7(プログラミング実習)、実習 14-3.を解いてみる。
その他参考書籍
- C++プログラミング入門 (グレゴリー サティア (著)、ダウグ ブラウン (著)、Gregory Satir (原著)、Doug Brown (原著)、望月 康司 (翻訳)、谷口 功 (翻訳)、オライリージャパン)
実習 14-3.
コード(BBEdit, Emacs)
sample244_3.cpp
#include <iostream> #include <assert.h> const int STACK_SIZE = 100; class stack { private: int count; int data[STACK_SIZE]; bool locked; int locked_by; public: stack() { count = 0; locked = false; } stack(const stack& old_stack); // ~stack() // operator = (const stack& old_stack) void push(const int item); int pop(); friend class access_stack; }; inline stack::stack(const stack& old_stack) { int i; for (i = 0; i < old_stack.count; ++i) { data[i] = old_stack.data[i]; } count = old_stack.count; } inline void stack::push(const int item) { assert(count >= 0 && count < static_cast<int>(sizeof(data)/sizeof(data[0]))); data[count] = item; ++count; } inline int stack::pop() { --count; assert(count >= 0 && count < static_cast<int>(sizeof(data) / sizeof(data[0]))); return (data[count]); } class access_stack { private: static int class_id; int id; public: access_stack() { id = class_id; ++class_id; } // access_stack(const access_stack& old_access_stack) // ~access_stack() // operator = (const access_stack& old_access_stack) void p(const stack& s); void lock(stack& s); void unlock(stack& s); }; int access_stack::class_id = 0; inline void access_stack::p(const stack& s) { int i = 0; for(i = 0; i < s.count; ++i) { std::cout << s.data[i] << ' '; } std::cout << '\n'; } inline void access_stack::lock(stack& s) { if (s.locked) std::cout << "既にロック済か、他のインスタンスがスタックを使用中です\n"; else { std::cout << "スタックをロックしました\n"; s.locked = true; s.locked_by = id; } } inline void access_stack::unlock(stack& s) { if (s.locked_by == id) { std::cout << "ロックを解除しました\n"; s.locked = false; } else std::cout << "他のインスタンスにロックされたのでロックを解除できません\n"; } int main() { stack a_stack; access_stack a_access_stack1; access_stack a_access_stack2; int i; for (i = 0; i < 10; ++i) { a_stack.push(i); } a_access_stack1.lock(a_stack); a_access_stack2.lock(a_stack); a_access_stack1.p(a_stack); a_access_stack2.unlock(a_stack); a_access_stack1.unlock(a_stack); a_access_stack2.lock(a_stack); a_access_stack1.lock(a_stack); a_access_stack2.p(a_stack); a_access_stack1.unlock(a_stack); a_access_stack2.unlock(a_stack); return (0); }
Makefile
# # FSFのg++コンパイラ用のMakefile # CC=g++ CFLAGS=-g -Wall all: sample244_3 sample244_3: sample244_3.cpp ${CC} ${CFLAGS} -o sample244_3 sample244_3.cpp clean: rm sample244_3
入出力結果(Terminal)
$ make && ./sample244_3 g++ -g -Wall -o sample244_3 sample244_3.cpp スタックをロックしました 既にロック済か、他のインスタンスがスタックを使用中です 0 1 2 3 4 5 6 7 8 9 他のインスタンスにロックされたのでロックを解除できません ロックを解除しました スタックをロックしました 既にロック済か、他のインスタンスがスタックを使用中です 0 1 2 3 4 5 6 7 8 9 他のインスタンスにロックされたのでロックを解除できません ロックを解除しました $
0 コメント:
コメントを投稿