<script type="text/javascript">
/**
* 这里定义Complex类,用来描述复数
*/
/**
* 这个构造函数为它所创建的每个实例定义了实例字段r和i
* 这两个字段分别保存复数的实部和虚部
* 他们是对象的状态
*/
function Complex(real , imaginary){
if( isNaN( real ) || isNaN( imaginary )) //确保两个实参都是数字
throw new TypeError(); //如果不都是数字则抛出错误
this.r = real; //复数的实部
this.i = imaginary; //复数的虚部
} /**
* 类的实例方法定义为原型对象的函数值属性
* 这里定义的方法可以被所有的实例继承,并为他们提供共享行为
* 需要注意的是,JavaScript的实例方法必须使用关键字this来存取实例的字段
*/
//当前复数对象加上另外一个复数,并返回一个新的计算和值后的复数对象
Complex.prototype.add = function(that){
return new Complex(this.r+that.r,this.i+that.i);
}; //当前复数乘以另外一个复数,并返回一个新的计算乘积之后的复数对象
Complex.prototype.mul = function(that){
return new Complex(this.r*that.r - this.i*that.i , this.r*that.i+this.i*that.r);
}; //计算复数的模,复数的模定义为原点(0,0)到复平面的距离
Complex.prototype.mag = function(){
return Math.sqrt(this.r*this.r + this.i*this.i);
}; //复数的求负运算
Complex.prototype.neg = function(){
return new Complex(-this.r , -this.i);
}; //将复数对象装换为一个字符串
Complex.prototype.toString = function(){
return "{"+this.r+","+this.i+"}";
}; //检测当前复数对象是否和另一个复数相等
Complex.prototype.equals = function(that){
return that != null && //必须有定义且不能是null
that.constructor ===Complex && //必须是Complex的是实例
this.r==that.r && this.i==that.i; //必须包含相同的值
}; /**
* 类字段(比如常量)和类方法直接定义为构造函数的属性
* 需要注意的是,累的方法通常不使用关键字this
* 他们只对其参数进行操作
*/
//这里预定义了一些对复数运算有帮助的类字段
//他们的命名全都是大写,用以表明他们是常量
//(在ECMAScript 5中,还能设置这些字段的属性为只读)
Complex.ZERO = new Complex(0,0);
Complex.ONE = new Complex(1,0);
Complex.I = new Complex(0,1); //这个类方法将由实例对象的toString方法返回的字符格式解析为一个Conplex对象
//或者抛出一个类型错误异常
Complex.parse = function(s){
try{
var m = Complex._format.exec(s) ; //利用正则表达是进行匹配
return new Complex(parseFloat(m[1]),parseFloat(m[2]));
}catch(e){
throw new TypeError("Can't parse '"+s+"' as a complex number.");
}
}; //定义累的“私有”字段,这个字段在Complex.parse()中用到了下划线前缀
//来表明他是内部使用的而不属于共有API的部分
Complex._format = /^\{([^,]+),([^}]+)\}/; //示例代码:
var c = new Complex(2,3); //使用构造函数创建新的对象
var d = new Complex(2,5) //用到了c的实例属性
console.log(c.add(d).toString()); //“{5,5}”:使用了实例的方法
//这个稍微复杂的表达式用到了类方法和类字段
console.log(Complex.parse(c.toString()). //将c转换为字符串
add(c.neg()). //加上他的复数
equals(Complex.ZERO)); //结果应当永远是零
</script>

JavaScript实现一个复数类的更多相关文章

  1. C++ 实验 使用重载运算符实现一个复数类

    实验目的: 1.掌握用成员函数重载运算符的方法 2.掌握用友元函数重载运算符的方法 实验要求: 1.定义一个复数类,描述一些必须的成员函数,如:构造函数,析构函数,赋值函数,返回数据成员值的函数等. ...

  2. c++primer,自定义一个复数类

    #include<iostream> #include<string> #include<vector> #include<algorithm> #in ...

  3. 定义一个复数类Complex

    #include<iostream> #include<math.h> using namespace std; class Complex{ public: Complex( ...

  4. 复数类(C++练习一)

    写一个复数类,实现基本的运算,目的熟悉封装与数据抽象. 类的定义 #include <iostream> #include <vector> using namespace s ...

  5. C++习题 复数类--重载运算符2+

    Description 定义一个复数类Complex,重载运算符"+",使之能用于复数的加法运算.参加运算的两个运算量可以都是类对象,也可以其中有一个是整数,顺序任意.例如,c1+ ...

  6. C++习题 复数类--重载运算符+

    Description 定义一个复数类Complex,重载运算符"+",使之能用于复数的加法运算.将运算符函数重载为非成员.非友元的普通函数.编写程序,求两个复数之和. Input ...

  7. YTU 2441: C++习题 复数类--重载运算符2+

    2441: C++习题 复数类--重载运算符2+ 时间限制: 1 Sec  内存限制: 128 MB 提交: 847  解决: 618 题目描述 定义一个复数类Complex,重载运算符"+ ...

  8. YTU 2440: C++习题 复数类--重载运算符+,-,*,/

    2440: C++习题 复数类--重载运算符+,-,*,/ 时间限制: 1 Sec  内存限制: 128 MB 提交: 1189  解决: 774 题目描述 定义一个复数类Complex,重载运算符& ...

  9. YTU 2439: C++习题 复数类--重载运算符+

    2439: C++习题 复数类--重载运算符+ 时间限制: 1 Sec  内存限制: 128 MB 提交: 1022  解决: 669 题目描述 定义一个复数类Complex,重载运算符"+ ...

随机推荐

  1. 关于jQuery表单选择中prop和attr的区别。

    今天用jQuery学习表单这一章节的内容,再次遇到表单全选时,不能进行第二次全选的情况.反复查看测试仍然找不到是什么原因.后来在网上查到原来是jQuery1.6以后的版本用到的是prop.用attr的 ...

  2. hexo摸爬滚打之进阶教程

    本文首发在我的个人博客:http://muyunyun.cn/ 写博客有三个层次,第一层次是借鉴居多的博文,第二层次是借鉴后经过消化后有一定量产出的博文,第三层次是原创好文居多的博文.在参考了大量前辈 ...

  3. 03 编译安装apache的简易配置

    1.监听端口,默认为80,在主配置文件 /etc/httpd24/httpd.conf中可以更改 2.持久连接 Include /etc/httpd24/extra/httpd-default.con ...

  4. 刨根究底字符编码之十一——UTF-8编码方式与字节序标记

    UTF-8编码方式与字节序标记 一.UTF-8编码方式 1. 接下来将分别介绍Unicode字符集的三种编码方式:UTF-8.UTF-16.UTF-32.这里先介绍应用最为广泛的UTF-8. 为满足基 ...

  5. php+mysql 除了设置主键防止表单提交内容重复外的另一种方法

    感觉好久没有更新博客了,一直在做网站及后台,也没有遇到让我觉得可以整理的内容,之前做的一个系统,已经完成了,后来客户又要求加一个功能,大概就是表单提交的时候,约束有一项不能和以前的内容重复,如图 比如 ...

  6. 一天搞定HTML----标签语义化04

    根据页面里不同的内容,选择最适合它的标签,而不通篇只用一种标签 标签语义化作用: 代码演示 通过比较- - -H5布局和DIV+CSS 布局- - -体现标签语义化 注意: 标签语义化,不仅仅只是指使 ...

  7. cs6安装

    [按下面步骤操作 无需序列号] ·打上补丁 永远无需序列号 (现在网上没什么能用的序列号) ·1双击CS软件安装,选择试用 ·2创建ID 输入自己邮箱和密码,姓名可以随意输入 ·3安装完成后 运行一次 ...

  8. kotlin成长之路

    前言: 从接触Kotlin开始,也就是我今天开启写技术博客的决定,文采不佳,欢迎各位阅读者的理解与指点.而该篇文章是最为博客新手的我对Kotlin成长的引导篇,所以内容一般是Kotlin技术博客的目录 ...

  9. 简单两步快速学会使用Mybatis-Generator自动生成entity实体、dao接口和简单mapper映射(用mysql和oracle举例)

    前言: mybatis-generator是根据配置文件中我们配置的数据库连接参数自动连接到数据库并根据对应的数据库表自动的生成与之对应mapper映射(比如增删改查,选择性增删改查等等简单语句)文件 ...

  10. 谈一下我们是怎么做数据库单元测试(Database Unit Test)的

    作者水平有限,如有错误或纰漏,请指出,谢谢. 背景介绍 最近在团队在做release之前的regression,把各个feature分支merge回master之后发现DB的单元测试出现了20多个失败 ...