欢迎来到学术参考网
当前位置:发表论文>论文发表

编译器毕业论文

发布时间:2023-02-24 01:41

编译器毕业论文

一. 简介
二、Linux系统下C编程原理
1. Linux系统的
2. Linux系统的主要构成
主要优异性能
3. gcc编译器的使用
三、总体设计
(1)、普通文件

(2)、目录文件
(3)、链接文件
(4)、设备文件
(5)、管道文件
2.进程基本介绍
3.库的使用

毕业论文请指教

摘要

本系统为学生成绩管理系统。采用的开发工具是 C++运行环境。 使用的技术有:数据库的访问;系统的查询。学生成绩管理系统是一个教育单位不可缺少的部分,使用计算机对学生成绩进行管理,具有手工管理所无法比拟的优点。例如检索迅速、查找方便、运行速度快、可靠性高、存储量大、保密性好、寿命长、成本低等。这些优点能够极大地提高学生成绩管理的效率,也是企业的科学化、系统化、网络化、正规化管理的重要途径。
信息管理系统(MIS)是进行信息的采集、存储、加工、使用、维护和使用的系统,它是随着管理科学和技术科学的发展而形成的。学生成绩管理系统是一个教育单位不可缺少的部分,它的内容对于学校的决策者和管理者来说都至关重要,所以学生成绩管理系统应该能够为用户提供充足的信息和快捷的查询手段。但一直以来人们使用传统人工的方式管理,这种管理方式存在着许多缺点,如:效率低、保密性差,可操作性低,另外时间一长,将产生大量的文件和数据,这对于查找、更新、储存和维护都带来了不少的困难。
现在有一个趋势,编译器厂商试图把其特有的“对象模型”和图形界面(GUI)细节推销给用户。比如微软的COM和Inprise的类属性“properties”。对于用户来说,这既不必要,也不情愿。我所希望看到的程序库,应该是用标准C++打造,界面灵活,值得信赖的程序库。通常,这些界面应该是平台无关的。C++的表达能力极强,即使不使用大量的宏,也应该足以达成这一要求。就算有些地方无法百分之百的遵守这一原则,也应该将对于平台和厂家的依赖性限制起来。这个目标的完成情况,可以反映软件工具产业对于应用程序开发行业的关注程度。我感觉目前对于那些独立的、跨平台厂商来说,并不存在相应的市场。如果能够建立这样的市场,也许能够促进厂商们为客户做出“真正有用的”产品。

关键词:学生、成绩、查询、管理。

前言

随着计算机技术的飞速发展,计算机在日常管理中应用迅速得到了普及,不久的将来将成为人们生活中不可或缺的一部分,利用计算机进行学生成绩信息的管理势在必行。本系统结合当前学校的实际,经过实际的需求分析,采用功能强大的C++作为开发工具而开发出来的单机版学籍管理系统。该系统适用性强,可操作性强,简单易行。
整个系统从符合操作简便、界面友好、灵活、实用、安全的要求出发,该系统定义添加、插入、查找、统计、删除、排序、修改成员函数,定义学生类数组和定义一个整型全局变量来记录学生,形成顺序表。插入,删除用顺序表的运算来实现,把姓名和学号都定义为String类变量有利于同时查找,排序使用冒泡法排序,打印姓名不为空的学生来做统计,输入姓名查询出学生后再重新给此学生成绩赋值来实现修改。经过实际使用证明,本文所设计的学生成绩管理系统可以满足学校学生成绩管理方面的需要。
学生成绩管理系统的内容对于学校的决策者和管理者来说都至关重要,所以学生成绩管理系统应该能够为用户提供充足的信息和快捷的查询手段。但一直以来人们使用传统人工的方式管理文件档案,这种管理方式存在着许多缺点,如:效率低、保密性差,操作麻烦,另外时间一长,将产生大量的文件和数据,这对于查找、更新和维护都带来了不少的困难。随着科学技术的不断提高,计算机科学日渐成熟,其强大的功能已为人们深刻认识,它已进入人类社会的各个领域并发挥着越来越重要的作用。
作为计算机应用的一部分,使用计算机对学生成绩信息进行管理,比手工管理有着无法比拟的优点.例如:检索迅速、查找方便、可靠性高、存储量大、保密性好、寿命长、成本低等。这些优点能够极大地提高学生档案管理的效率,也是企业的科学化、正规化管理,与世界接轨的重要条件。
因此,开发这样一套成绩管理软件成为很有必要的事情,在下面的各章中我们将以开发一套学生成绩管理系统为例,谈谈其开发过程和所涉及到的问题及解决方法。下面就让我们开始正文的介绍。

第一章 系统的概述
系统概述:
本系统为学生成绩管理系统,是一个具有综合性学校学生成绩管理系统,它集成了学生成绩的添加,学生成绩的查询,学生成绩的统计,学生的成绩的排序,修改与删除等多种功能,其开发主要包括数据库的建立和维护及查询,修改,排序,统计等功能的实现,因而具有较强的实用性,先进性和可操作性。
1,1系统及其需求分析
1,1,1系统需求
对于一个综合性较强的学校,我校是专科本科于一体的多层次,多功能,综合型学校,未来的几年我学院将更进一步的发展,全院的所有成员都在为学院的更上新台阶而努力奋斗着,2007年通过教育部专家组的检查评估,我院(郑州经济管理干部学院)和纺专已经联合升本——河南工程学院,成为河南省普通本科学校.到目前到止,学校对学生成绩的管理工作仍然是以电子表格Excel2000为主,由于近几年学校的快速发展,招生规模原来越大,在校学生已达到几万多人,这样学生成绩管理,特别是查找学生,学生统计,学生的修改,删除,排序等带来一定的操作性困难,也给我校老师带来了很多的麻烦,教务处管理员急切希望开发出符合我校实际的学生成绩管理系统.
通过调查分析,要求该系统具有以下功能:
由于操作人员的计算机操作水平相对较差,要求有良好的人机界面.
由于该系统的使用要有数据安全性,要求有较好的用户权限管理.
原始数据的处理,简单方便.
方便的数据查询,支持多条件查询.
方便数据输出报表的打印.
数据主要计算自动完成,尽量减少人工干预.
1,1,2可行性分析
目的:
可行性研究的目的是以最小的代价在尽可能的时间内确定问题是否能解决.能及时的有效的操作,为操作者带来更大的便利,节省更多的时间,尽可能的使操作人性化,简单化,高效化。通过课程设计培养了我的动手能力以及综合运用所学的C++语言基础理论,基础知识,基本技能,进行程序分析和程序开发,提高在实际开发中解决问题的能力,达到了能够利用C++语言进行应用程序的规划,分析,设计和实施,更能进一步使我对这门语言有深刻的理解和更好的得到巩固,更能对我所学的知识得到检验。
经济上的可行性:
由于现在我校为各办公室配备了微机,而且用于学生成绩管理的微机都是P4级的机器,在存储量,速度方面都能满足数据库运行的要求.利用这个系统也可以节省不必要的开支。
技术上的可行性:
由于本系统管理的对象实体是:学生成绩的删除,修改,查询,替换,统计等,他们之间通过学生可以联系起来,涉及的计算过程不是很复杂,在技术难度方面,由于有指导老师的指导和图书馆有丰富的相关参考文献,特别是网上资料丰富,参考一些功能模块程序的设计的系统语言几代码,以及这些年来我从事C/C++中学习的知识以及自己的实际操作经验总结,本系统目标的实现是完全可以的.
本系统的设计是在C++中文版环境下,使用C/C++开发成功.它可运行于C++相关平台的数据库开发系统.C++它不仅可以简化数据库管理,而且应用程序的开发流程更为合理;它使组织数据,定义数据库规则和建立应用程序等工作变行简单易行,用户可以快速地创建表单,查询,修改和统计学生的信息.

1,2系统设计背景
21世纪以来,人类经济高速发展,人们的生活发生了日新月异的变化,特别是计算机的应用及普及;已经深入到政治,经济,生活的各个领域,便人们从过去繁复的手工劳动中得以解脱.科学技术的发展决定了我们必须利用网络,利用科技来解决显示生活中许多问题,学校信息管理系统软件为学校学生成绩管理部门带来了极大方便;因此,开发一套完善的学生学籍管理系统显得尤为必要.

1,3系统功能简介
本系统适用于大中专院校,其功能主要分为五大类:
系统维护:维护系统的正常运行和安全性设置,包括数据备份,数据恢复,信息的查询,修改,删除和统计等.
数据处理:用于对插入学生,查找学生,删除学生及删除信息等数据录入,是数据查询,报表的主要数据来源.

第二章 怎样开发一个学生成绩管理系统

2.1 编程环境的选择
C/C++应用程序开发工具,使目前最为广泛的、易学易用的面向对象的开发工具。C/C++语言提供了简单的语言运行环境,利用这些代码可用于设计界面和实现各种功能,也简化了界面设计过程,从而有效的提高了应用程序的运行效率和可靠性。故而,实现本系统C/C++是一个相对较好的选择。

2.2 关系型数据库的实现
Access2000 就是关系数据库开发工具,数据库能汇集各种信息以供查询、存储和检索。Access 的优点在于它能使用数据表示图或自定义窗体收集信息。数据表示图提供了一种类似于 Excel 的电子表格,可以使数据库一目了然。另外,Access 允许创建自定义报表用于打印或输出数据库中的信息。Access也提供了数据存储库,可以使用桌面数据库文件把数据库文件置于网络文件服务器,与其他网络用户共享数据库。Access 是一种关系数据库工具,关系数据库是已开发的最通用的数据库之一。如上所述,Access 作为关系数据库开发具备了许多优点,可以在一个数据包中同时拥有桌面数据库的便利和关系数据库的强大功能。

2.3 二者的结合(DBA)
微软的JET数据库引擎提供了与数据库打交道的途径,我们是通过它以及c++在面向Internet的编程中却无任何优势可言.跨平台的电子商务软件最害怕顾及各种平台之间的天差地别的系统调用,最害怕时不时的由于内存泄漏而crash.c/c++的优势在这里却成为了劣势.即使在windows平台上开发基于windows dna的solution。
DATA 控件在数据库中的信息与将信息显示给用户看的C++程序之间架起了一座桥梁。我们可以设置DATA控件的各个属性,告诉它要调用那个数据库的哪个部分。缺省情况下,DATA控件根据数据库中的一个或多个数据表建立一个dynaset-type(动态集合)类型的记录集合。一个记录集合是动态的也就意味着,当原来的数据表中的容改变了以后,该记录集合中的记录也会随之改变。DATA控件还提供了用来浏览不同记录的各种跳转按钮。将DATA控件放置在窗体中之后,我们还必须在该控件与要处理的数据库之间建立联系。

第三章 C++语言的及其编程环境

3.1 C++语言概述
C++,这个词在中国大陆的程序员圈子中通常被读做“C加加”,而西方的程序员通常读做“C plus plus”,它是一种使用非常广泛的计算机编程语言。C++是一种静态数据类型检查的,支持多重编程范式的通用程序设计语言。它支持过程化程序设计、数据抽象、面向对象程序设计、泛型程序设计等多种程序设计风格。
另外,就目前学习C++而言,可以认为他是一门独立的语言;他并不依赖C语言,我们可以完全不学C语言,而直接学习C++。根据《C++编程思想》(Thinking in C++)一书所评述的,C++与C的效率往往相差在正负5%之间。所以有人认为在大多数场合C++ 完全可以取代C语言(然而我们在单片机等需要谨慎利用空间、直接操作硬件的地方还是要使用C语言)。

3.2 C++语言发展
C++语言发展大概可以分为三个阶段:第一阶段从80年代到1995年。这一阶段C++语言基本上是传统类型上的面向对象语言,并且凭借着接近C语言的效率,在工业界使用的开发语言中占据了相当大份额;第二阶段从1995年到2000年,这一阶段由于标准模板库(STL)和后来的Boost等程序库的出现,泛型程序设计在C++中占据了越来越多的比重性。当然,同时由于Java、C#等语言的出现和硬件价格的大规模下降,C++受到了一定的冲击;第三阶段从2000年至今,由于以Loki、MPL等程序库为代表的产生式编程和模板元编程的出现,C++出现了发展历史上又一个新的高峰,这些新技术的出现以及和原有技术的融合,使C++已经成为当今主流程序设计语言中最复杂的一员

3.3 C++的设计原则
• C++设计成静态类型、和C同样高效且可移植的多用途程序设计语言。
• C++设计成直接的和广泛的支援多种程序设计风格(程序化程序设计、资料抽象化、面向对象程序设计、泛型程序设计)。
• C++设计成给程序设计者更多的选择,即使可能导致程序设计者选择错误。
• C++设计成尽可能与C兼容,籍此提供一个从C到C++的平滑过渡。
• C++避免平台限定或没有普遍用途的特性。
• C++不使用会带来额外开销的特性。
• C++设计成无需复杂的程序设计环境。

3. 4 C++的Hello World程序
在使用兼容C89标准(也称为ANSI C)的编译器时,下面这个程序显示“Hello, world!”然后结束运行:
(事实上这并不是符合98标准[ISO C++]的C++程序,而且在多数编译器上这个程序也不能运行,若要在比较旧的编译器上编译该程序,应将iostream改为iostream.h)

#include <iostream>
int main()
{ std::cout << "Hello, world!\n";
return 0;}
在使用兼容C++99标准(ISO/IEC 14882-1998)的编译器时,下面的程序也是可以的:
#include <iostream>
using namespace std;
int main()
{ cout << "Hello, world!" << endl;
return 0;
}
根据ISO C++的规定,main函数的形式只能是
int main()
{ ...}
以及
int main(int argc,char * argv[])
{ ... }
尽管如此,但在大部份(其实是在Windows平台下的大部分)编译器上,
void main()
{ ... }
也被支持。

第四章 使用Access2000 实现关系型数据库

4.1 数据库的概念
数据库是一种存储数据并对数据进行操作的工具。数据库的作用在于组织和表达信息,简而言之,数据库就是信息的集合。计算机的数据库可以分为两类:非关系数据库(flat-file)和关系数据库(relational)。关系数据库中包含了多个数据表的信息,数据库含有各个不同部分的术语,象记录、域等。

4.2 新建一个数据库
创建任何一个数据库的第一步是仔细的规划数据库,设计必须是灵活的、有逻辑的。创建一个数据库结构的过程被认为是数据模型设计。
1. 标识需要的数据;
2. 收集被标识的字段到表中;
3. 标识主关键字字段;
4. 绘制一个简单的数据图表;
5. 规范数据;
6. 标识指定字段的信息;
7. 创建物理表。

4.3 实现数据库之间的联系
数据库之间的关系指明两个库之间共享一个共同的关键字值。一个连接是指一种虚拟的表,这种表是在当用户要求从相互关联的各个不同的表中获取信息时建立的,关键字段用于在相互连接的不同表中查找匹配的记录。一个更高级的连接形式称为自连接。这种连接是指一个表被连接到它自己的一个字段,或在不同的纪录中由重复数据的组合字段。数据库中有三种不同类型的关键字:主关键字、组合关键字和外关键字。在表中使用的关键字类型用于描述库表示什么以及在数据库中如何与其它的库建立关系。

第五章 系统总体规划

5.1 系统功能
功能分析:定义添加、插入、查找、统计、删除、排序、修改成员函数。定义学生类数组和定义一个整型全局变量来记录学生,形成顺序表。插入,删除用顺序表的运算来实现,把姓名和学号都定义为String类变量有利于同时查找,排序使用冒泡法排序,打印姓名不为空的学生来做统计,输入姓名查询出学生成绩后再重新给此学生成绩赋值来实现修改。
5.2 设计结构
设计结构:定义一个学生类包含(姓名 学号 成绩 学生序号 总成绩 平均成绩)成员变量和添加、插入、查找、统计、删除、排序、修改成员函数。定义学生类数组和一个整型全局变量来记录学生,形成顺序表。

5.3程序设计技巧
程序应用要点:
1.添加学生 或 插入学生时 请输入4个汉字或8个英文字母的姓名 学号输入10个以内数字
2.插入学生 时候按4看统计记住你要插入的序号 输入你要插入序号
3.其他操作看提示可完成
注释:系统的具体程序见附录

基于图结构应用《编码,译码器》的设计与实现 这个毕业设计应该从什么思路下手啊~~计算机专高手请指点

兄弟你这个论文有点难度了。不是随便拉拉就行了。得找专业书籍慢慢找和高人指导了。
我查到点不指导有没有用。
Turbo卷积码(TCC)是3G无线系统中所采用的前向错误校正(FEC)机制的整体部分。然而,Turbo译码器所带来的计算负担非常重,并不太适合采用传统DSP或RISC处理器实现。由于现场可编程逻辑阵列(FPGA)内在的并行结构,FPGA为解决3G基站收发器中所需要的符号速率FEC和其它计算密集的任务提供了一个高性能信号处理平台基础。

Turbo 编码

级联码方案(Concatenated coding schemes)是为了通过结合两个或更多相对简单的分量或构造模块码来获得较高的编码增益。Turbo码认为是对级联码结构的一种改进,其中采用迭代算法对相关的码序列进行译码。Turbo码是通过将两个或更多分量码应用到同一数据序列的不同交织版本上构成的。对于任何传统单分量编码,译码器的最后一级生成的都是硬判决译码数据位。为了使象Turbo码这样的级联码方案工作得更好,译码算法不应被限制为只能在译码器间传递硬判决。为最好地利用每个译码器获得的信息,译码算法必须可以实现软判决交换,而不是采用硬判决。对于采用两个分量码的系统,译码的概念是指将来自一个译码器的软判决输入到另一个译码器的输入,并将此过程重复几次以获得更好的判决,如图1所示 。

3GPP Turbo 编码器

图2为3GPP编码器。

输入数据流输入到RSC1,它为每个输入比特生成一个对等比特(Parity Bit)。输入数据还经过交织后由RSC2处理生成第二个对等比特流。
3GPP标准定义,输入块的长度在40至5114 位之间。编码器生成一个速率为1/3的包括原始输入位和两个对等位的系统码。通过打孔方法可以获得1/2编码速度的编码。递归系统编码器的实现比较直接,然而交织器则不那么简单,要比标准的卷积或块交织器复杂。

一旦将输入数据块长度K 提供给编码器以后,编码器将计算交织矩阵行数R和列数 C,并创建相应的交织数据结构。R 和 C 是数据块长度K的函数。在输入符号被加载到交织矩阵以后,那么将根据一定的顺序进行行间交换和列间交换。交换模式是根据块长度K选择的(即依赖于K)。行和列交换完成后,通过逐列读出交织矩阵数据就可以得到最终的交织序列。在数据读出时需要进行删减操作,以保证在输出中只有正确的输入符号,请注意,交织阵列包含的数据位通常比K个原始输入符号要多 ,因为R C>K。然后,新的序列经过RSC2编码生成第二个对等位流。
实现交织器的一种方法是在存储器中存储完整的交换序列。即,一旦K 给定,即调用一个初始化例程(运行在处理器上的软件例程或利用FPGA中的功能单元)生成相应的交换序列,然后将这一信息存储在存储器中。然而,这一方法需要大量的存储器。利用Virtex -E FPGA 技术提供的 4096位每块的片上存储器,将需要[5114 13/4096]=17个存储器块。

在我们的方法中,采用一个预处理引擎生成一个序列值(存储),这一序列值被存储起来,交织器地址发生器将使用这些序列值。这一硬件单元采用几个小型数据结构(素数表)来计算所需要的序列。这一准备过程需要的时钟周期数与信息块的长度成比例。例如,对于K=40的块需要280时钟周期,而对于最大块长度K=5114,则需要 5290个时钟周期。该过程只需要在块长度变化时进行。地址发生器利用这些更为紧凑的数据结构来实时生成交织地址。

3GPP Turbo 译码器

译码器包括两个MAP(最大后验概率)译码器和几个交织器。Turbo算法的优良的性能源于可以在两个MAP译码器间共享可靠性信息(extrinsic data,外数据,或称先验数据)。

在我们的设计中,MAP译码器采用的是Bahl, Cocke, Jelinek 和 Rajiv (BCJR) 算法。BCJR算法计算每个符号的最大后验对数似然率,并且是一种真正的软判决算法。考虑到数据是以块的形式传输的,因此可以在时间维中前向或反向搜索一个符号序列。对于任一序列,其出现概率都是单独符号出现概率的乘积。由于问题是线性的,因此序列概述可以利用概率的对数和来代替。

为了与一般文献中的习惯一致,我们将译码迭代的前向和反向状态概率分别利用 和 来表示。通常,BCJR算法要求在接收到整个信息后才开始解码。对于实时应用,这一限制可能太严格了。例如,3GPP Turbo译码器将需要大量存储器存储一个5114符号信息块的完全状态结构(state trellis)。对于单片FPGA设计来说,这需要的存储资源太多了。与维特比(Vitebi)算法类似,我们可以先从全零向量 O和数据{yk}(k 从 n 到 n-L) 开始反向迭代。L次反向迭代可获得非常好的 n-L近似值。只要L选择合适,最终的状态标志(state metric)就是正确的。可以利用这一性质在信息结束前就开始进行有效的位译码。

L 被称为收敛长度。其典型值大约是译码器约束长度的数倍(通常为5至10倍),并随着信噪比的降低而增加。

通常,Turbo译码算法将计算所有的 (对整块信息),将这些数值存储起来,然后在反向迭代中与反向状态概率一起用来计算新的外信息(extrinsic information,或称先验信息)。我们的设计中采用了窗口化方法。

译码过程以一个前向迭代开始,计算包含L 个接收符号的块i的 值。同时,对未来(i+1)块进行一个反向迭代(标号 )。对块i+1的反向迭代结束时,就获得了开始对块i 进行反向迭代所需要的正确的 初始向量。 与此同时对数似然函数(Lall)也在进行。 每一 和 处理过程都需要8个max* 操作 - 每个针对状态结构(tellis)中的8个结点之一。最终的对数似然计算需要14个并行max* 运算符。为了提供可接受的译码速率,在设计中采用了38个max* 功能单元。

从 C描述到FPGA设计

FPGA Turbo 编码译码器设计是利用基于C的设计和验证方法进行的,如图3所示。

算法开发阶段采用具有定点C类型的Art Library 来对定点计算的位真(bit-true)效应进行准确建模。在这一阶段考察了几种可能算法的定点性能。一旦选定正确的量化算法,就可利用A|rtDesignerPro创建一个专用DSP架构。A|rtDesignerPro的一个最强大的功能之一是可以插入和利用专用的数据通道核心(称为专用单元,ASU)。利用这些ASU加速器核心可以使我们处理Turbo译码器算法内在的计算复杂性。

A|rtDesignerPro可自动完成寄存器分配、调度和控制器生成。在Turbo编码译码器设计中, A|rtDesignerr的自动循环合并可获得最佳的;任务调度,MAP译码步骤的内部循环都只有一个周期长。

A|rtDesignerPro生成的最终结果是可综合的寄存器级(RT-level) VHDL或Verilog 描述。基于C的工具流支持FPGA专用功能。例如,可利用BlockRAM自动构造RAM,而寄存器文件也可利用分布式存储器而不是触发器来实现 。

最后,逻辑综合和Xilinx实施工具套件将RTL HDL 转换为 FPGA 配置位流。

FPGA Turbo 编码译码器实现

A|rtDesigner创建的Turbo编码器和译码器核心硬件结构包含许多专用ASU加速器。其中最重要的一个加速器完成max* 操作。max* 运算符根据下式计算两个幂值a 和 b:

max* (a,b)=ln(expc(a)+expc(b))。

如 图4所示, max* 运算是通过选择(a,b)最大值,并应用一个存储在查找表(LUT)中的校正因子近似进行的。这一近似算法非常适合利用Xilinx FPGA 实现,其中LUT是其最终基本构造单元。

结果

Turbo译码算法硬件字长的选择极大地影响总体性能。利用C-to-FPGA设计流程,这一定点分析是完全在C环境中完成的。结果示于图 5。

上图显示出了我们的浮点Turbo译码器算法和对应的定点算法之间的性能差别。仿真是在5114块长度、5次译码迭代和AWGN信道模型情况下进行的。结果清晰明显出性能的损失是非常小的。

我们的Turbo译码器的定点性能做为译码器迭代次数的函数 ,对于1.5 dB SNR,位错率为10-6。

译码器功能的实现非常具有挑战性,我们同时针对Virtex-E和 Virtex-II 器件进行了适配。Virtex-II 器件实施是采用运行在1.85 speedfile数据库上的Xilinx 4.1i 实施工具集完成的。利用XC2V1000BG575-5 FPGA实现的最终设计,达到了66 MHz 的时钟性能,消耗了3,060个逻辑片 和 16个块RAM。对于从40至 5114符号长度的块,采用5次译码迭代循环的情况下,译码器达到了2 至6.5 百万符号每秒(Msym/s)的吞吐量。编码器占用了903个逻辑片、3个块RAM并支持83 MHz时钟频率。对于从40至5114位的块长度,速率可达到9 至20 Msym/s。

能用上就好了,用不上别怪我。对不起哈~祝福你~

上一篇:论文狗检测准确吗

下一篇:创业意向研究论文