Archive

Archive for March 6th, 2010

C++ Primer 学习笔记:标准库类型

March 6th, 2010 leeing No comments

C++ Primer 学习笔记二:标准库类型

1. 有一种情况下,必须总是使用完全限定的标准库名字:在头文件中。因为头文件的内容会被预处理器复制到程序中。用#include包含文件时,相当于头文件中的文本将成为我们编写的文件的一部分。如果在头文件中放置using声明,就相当于每个包含此头文件的程序都放置了同一using声明,不论该程序是否需要using声明。而通常,头文件中只应当定义确实必要的东西。

2. 字符串字面值与标准库中的string并不是同一个类型,这是因为历史的原因及C兼容性。
当进行string对象和字符串字面值混合连接操作时,+ 操作符的左右操作数必须至少有一个是string类型的:

string str = "hello " + "world" // 非法
string str0 = "world";
string str1 = "hello" + ", " + str0 // 非法

3. 从标准输入读取string,将:

  • 读取并忽略开头所有的空白字符(如空格,换行符,制表符)
  • 读取字符直到再次遇到空白字符,读取终止。

例如,如果输入为:’        hello world     ‘,则实际保存的是: ‘hello’
一种不常见的初始化方式为:
string str(n,c):将str初始化为字符 c 的n个副本。

4. string.empty() 将返回bool值,判断是否为空串。

5. string:size_type。因为string::size()返回的是string::size_type类型的值,string类类型和许多其它库类型都定义了一些配套类型,通过这些配套类型,库类型的使用就可以与机器无关,size_type定义为与unsigned类型(unsigned int或者unsigned long)具有相同的含义,而且可以保证足够大的能够存储任意string对象的长度。为了使用由string类型定义的size_type类型,必须加上string::来限定所使用的size_type是由string类定义的。
任何存储string的size操作结果的变量必须为string::size_type类型。特别重要的是,不要把size的返回值赋给一个int变量,这是为了避免溢出现象的发生。
对于vector,则应当使用vector::size_type。
并且,习惯用!=而不是 <来编写循环判断条件,如:

for(vector::size_type ix = 0; ix ! = vec.size(); ++ ix) { }

并且,由于string, vector都是可以动态增长的,因此倾向于在每次循环时测试size的当前值,而不是在进入循环前就存储size值的副本。像size() 这样的小库函数一般定义为内联函数,所以每次循环过程中调用它的运行代价是比较小的。

Read more…

Categories: C++ Tags:

OMNeT++ 的仿真流程

March 6th, 2010 leeing 1 comment

Simulation with OMNeT++

用OMNeT++进行仿真的大致流程如下:

  1. 一个OMNeT++模型是用通过交换信息来通讯的组件(模块)来构建的。模块可以嵌套,也就是说,几个模块可以组成一个复合模块。在创建模型时,你需要将系统映射到一个相互通讯的模块体系中。
  2. 用NED语言定义模型的结构。你可以在OMNet++提供的IDE中以文本或图形化方式来编辑NED文件。
  3. 模型的活动组件(简单模块)需要用C++来编程,当中要使用仿真内核及类库。
  4. 提供一个拥有配置和参数的omnetpp.ini文件给模型,一个配置文件可以用不同的参数来描述若干个仿真过程。
  5. 构建仿真程序并运行它。你可以将代码链接到OMNet++的仿真内核及其提供的一个用户接口:命令行和交互式接口或图形化接口。
  6. 仿真结果将写入输出向量和输出标量文件中。你可以使用IDE中提供的分析工具来进行可视化。结果文件是普通的文本,所以你能用R,Matlab或其它工具来进行绘图。

原文在 >> 这里 <<。

Categories: OMNeT++, 计算机网络 Tags: