热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

ITK配准框架中的Subject/Observer模式及优化过程模拟演示3

      这里先给出程序的主要类图:一些成员函数我以简写的方式在类图中给出,如 Add() 表示 AddObserver() 等,类中只列出了一些比较重要的

      这里先给出程序的主要类图:一些成员函数我以简写的方式在类图中给出,如 Add() 表示 AddObserver() 等,类中只列出了一些比较重要的数据成员及方法。还有类之间的聚集关系表示的可能不太对,VISIO 太会操作,自己对 UML 也不是很熟悉,差不多意思是可以表示明白的。

1. 类继承结构图:

ObserverTest1

2. Command/Observer 模式的类结构图:

ObserverTest2

以上两个类结构图与 ITK 中基本相似,以后会对图像配准源代码的执行流程给出一个简单的分析,并给出用到的主要类之间的结构图。

下面给出对应头文件的实现代码:

2. MyEventObject 类

1:  

2: //MyEventObject.cpp

3: #include "MyEventObject.h"

4: #include

5:  

6: //

7: void MyEventObject::Print(std::ostream& os) const

8: {

9: MyIndent indent;

10:  

11: this->PrintHeader(os,0);

12: this->PrintSelf(os, indent.GetNextIndent());

13: this->PrintTrailer(os,0);

14: }

15:  

16: //默认实现

17: void MyEventObject::PrintHeader(std::ostream& os, MyIndent indent) const

18: {

19: os <

20: os <"itk::" <<this->GetEventName() <<" (" <<this <<")/n";

21: }

22:  

23: //

24: void MyEventObject::PrintTrailer(std::ostream& os, MyIndent indent) const

25: {

26: os <

27: }

28:  

29: void MyEventObject::PrintSelf(std::ostream&, MyIndent) const

30: {

31: }


3.MyIndent 类&#xff1a;

1: //MyIndent.cpp

2: #pragma once

3: #include "MyIndent.h"

4:  

5: #define ITK_STD_INDENT 4 //标准缩进量

6: #define ITK_NUMBER_OF_BLANKS 40 //最大缩进量

7:  

8: //空格

9: static const char blanks[ITK_NUMBER_OF_BLANKS&#43;1] &#61; " ";

10:  

11: MyIndent* MyIndent::New()

12: {

13: return new Self;

14: }

15:  

16:  

17: //设置下一个缩排级别

18: MyIndent MyIndent::GetNextIndent()

19: {

20: int indent &#61; m_Indent &#43; ITK_STD_INDENT;

21: if ( indent > ITK_NUMBER_OF_BLANKS )

22: {

23: indent &#61; ITK_NUMBER_OF_BLANKS;

24: }

25: return indent;

26: }

27:  

28: //以锯齿状打印缩排格式&#xff0c;用空格控制

29: //该函数的实现不能放在 头文件中, 否则在多个文件中包含会造成重复定义的错误

30: std::ostream& operator<<(std::ostream& os, const MyIndent& ind)

31: {

32: //输出 ind.m_Indent 个空格...

33: os <

34: return os;

35: }


 

4.MyObject 类&#xff1a;

1:  

2: #include "MyObject.h"

3: #include "MyCommand.h"

4: #include "SubjectObserver.h"

5: #include

6:  

7: //Object 类成员函数实现:

8: MyObject::MyObject() : m_Subject(NULL)

9: {

10: //this->Modified();

11: }

12: MyObject::~MyObject()

13: {

14: delete m_Subject;

15: }

16:  

17: //New() 创建对象实例

18: MyObject* MyObject::New()

19: {

20: return new Self;

21: }

22: //Delete() 销毁对象

23: void MyObject::Delete()

24: {

25: delete this;

26: }

27: //返回指定 Command 指针

28: MyCommand* MyObject::GetCommand(unsigned long tag)

29: {

30: if (this->m_Subject)

31: {

32: return this->m_Subject->GetCommand(tag);

33: }

34: return NULL;

35: }

36:  

37: //注册观察者以及其感兴趣的事件

38: //程序中的 optimizer->AddObserver(MyIterationEvent(), observer); 即为此函数;

39: //MyOptimizer 继承自 MyObject,而其 AddObserver 又调用了 Subject 中的 AddObserver

40: unsigned long MyObject::AddObserver(const MyEventObject & event, MyCommand *cmd)

41: {

42: if (!this->m_Subject)

43: {

44: this->m_Subject &#61; new Subject;

45: }

46: //optimizer 中的 AddObserver 调用了 Subject 中的 AddObserver

47: return this->m_Subject->AddObserver(event, cmd);

48: }

49: //

50: unsigned long MyObject::AddObserver(const MyEventObject & event, MyCommand *cmd) const

51: {

52: if (!this->m_Subject)

53: {

54: //去掉 MyObject 的 const 属性

55: Self * me &#61; const_cast( this );

56: me->m_Subject &#61; new Subject;

57: }

58: return this->m_Subject->AddObserver(event,cmd);

59: }

60: //

61: void MyObject::RemoveObserver(unsigned long tag)

62: {

63: if (this->m_Subject)

64: {

65: this->m_Subject->RemoveObserver(tag);

66: }

67: }

68: //

69: void MyObject::RemoveAllObservers()

70: {

71: if (this->m_Subject)

72: {

73: this->m_Subject->RemoveAllObservers();

74: }

75: }

76:  

77: //InvokeEvent(): 触发特定事件的发生

78: //优化程序每迭代一次, 便调用该方法触发一次 MyIerationEvent() 事件

79: //而 InvokeEvent() 调用了 subject 中的 InvokeEvent()

80: void MyObject::InvokeEvent( const MyEventObject & event )

81: {

82: if (this->m_Subject)

83: {

84: this->m_Subject->InvokeEvent(event,this);

85: }

86: }

87: //

88: void MyObject::InvokeEvent( const MyEventObject & event ) const

89: {

90: if (this->m_Subject)

91: {

92: this->m_Subject->InvokeEvent(event,this);

93: }

94: }

95: //检查是观察者注册了 event 事件

96: bool MyObject::HasObserver( const MyEventObject & event ) const

97: {

98: if (this->m_Subject)

99: {

100: return this->m_Subject->HasObserver(event);

101: }

102: return false;

103: }

104: //打印观察者相关信息

105: bool MyObject::PrintObservers(std::ostream& os, MyIndent indent) const

106: {

107: if (this->m_Subject)

108: {

109: return this->m_Subject->PrintObservers(os, indent);

110: }

111: return false;

112: }

113:  

114: //ITK 中, Print() 对所有对象都是一样的, 它只是调用了相应的

115: //header/self/trailer 虚方法

116: void MyObject::Print(std::ostream& os, MyIndent indent) const

117: {

118: this->PrintHeader(os, indent);

119: this->PrintSelf(os, indent.GetNextIndent());

120: this->PrintTrailer(os, indent);

121: }

122:  

123: //默认实现

124: void MyObject::PrintHeader(std::ostream& os, MyIndent indent) const

125: {

126: os <"RTTI typeinfo: "

127: <this ).name() <

128: }

129: //打印自身的相关信息

130: void MyObject::PrintSelf(std::ostream& os, MyIndent indent) const

131: {

132: os <"Observers: " <

133:

134: if(!this->PrintObservers(os, indent.GetNextIndent()))

135: {

136: os <"none/n";

137: }

138: }

139: //默认实现

140: void MyObject::PrintTrailer(std::ostream& os, MyIndent indent) const

141: {

142: }

143:  

144: //该方法允许 MyObject 的所有子类通过 <<输出自己的相关信息, 它调用了 Print() 成员方法

145: std::ostream& operator<<(std::ostream& os, const MyObject& o)

146: {

147: o.Print(os);

148: return os;

149: }


推荐阅读
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
  • 预备知识可参考我整理的博客Windows编程之线程:https:www.cnblogs.comZhuSenlinp16662075.htmlWindows编程之线程同步:https ... [详细]
  • Java自带的观察者模式及实现方法详解
    本文介绍了Java自带的观察者模式,包括Observer和Observable对象的定义和使用方法。通过添加观察者和设置内部标志位,当被观察者中的事件发生变化时,通知观察者对象并执行相应的操作。实现观察者模式非常简单,只需继承Observable类和实现Observer接口即可。详情请参考Java官方api文档。 ... [详细]
  • JDK源码学习之HashTable(附带面试题)的学习笔记
    本文介绍了JDK源码学习之HashTable(附带面试题)的学习笔记,包括HashTable的定义、数据类型、与HashMap的关系和区别。文章提供了干货,并附带了其他相关主题的学习笔记。 ... [详细]
  • 本文记录了在vue cli 3.x中移除console的一些采坑经验,通过使用uglifyjs-webpack-plugin插件,在vue.config.js中进行相关配置,包括设置minimizer、UglifyJsPlugin和compress等参数,最终成功移除了console。同时,还包括了一些可能出现的报错情况和解决方法。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • 本文介绍了深入浅出Linux设备驱动编程的重要性,以及两种加载和删除Linux内核模块的方法。通过一个内核模块的例子,展示了模块的编译和加载过程,并讨论了模块对内核大小的控制。深入理解Linux设备驱动编程对于开发者来说非常重要。 ... [详细]
  • 本文介绍了如何使用Express App提供静态文件,同时提到了一些不需要使用的文件,如package.json和/.ssh/known_hosts,并解释了为什么app.get('*')无法捕获所有请求以及为什么app.use(express.static(__dirname))可能会提供不需要的文件。 ... [详细]
  • 海马s5近光灯能否直接更换为H7?
    本文主要介绍了海马s5车型的近光灯是否可以直接更换为H7灯泡,并提供了完整的教程下载地址。此外,还详细讲解了DSP功能函数中的数据拷贝、数据填充和浮点数转换为定点数的相关内容。 ... [详细]
  • 重入锁(ReentrantLock)学习及实现原理
    本文介绍了重入锁(ReentrantLock)的学习及实现原理。在学习synchronized的基础上,重入锁提供了更多的灵活性和功能。文章详细介绍了重入锁的特性、使用方法和实现原理,并提供了类图和测试代码供读者参考。重入锁支持重入和公平与非公平两种实现方式,通过对比和分析,读者可以更好地理解和应用重入锁。 ... [详细]
  • NotSupportedException无法将类型“System.DateTime”强制转换为类型“System.Object”
    本文介绍了在使用LINQ to Entities时出现的NotSupportedException异常,该异常是由于无法将类型“System.DateTime”强制转换为类型“System.Object”所导致的。同时还介绍了相关的错误信息和解决方法。 ... [详细]
  • 本文介绍了Java集合库的使用方法,包括如何方便地重复使用集合以及下溯造型的应用。通过使用集合库,可以方便地取用各种集合,并将其插入到自己的程序中。为了使集合能够重复使用,Java提供了一种通用类型,即Object类型。通过添加指向集合的对象句柄,可以实现对集合的重复使用。然而,由于集合只能容纳Object类型,当向集合中添加对象句柄时,会丢失其身份或标识信息。为了恢复其本来面貌,可以使用下溯造型。本文还介绍了Java 1.2集合库的特点和优势。 ... [详细]
author-avatar
爱心常在V_991
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有