PowerPoint 演示文稿
|
|
|
- 玄 洪
- 9 years ago
- Views:
Transcription
1 第四讲 消息传递编程接口 MPI 一 MPI 编程基础
2 主要内容 MPI 安装 程序编译与运行 MPI 编程基础 MPI 程序基本结构 MPI 数据类型 消息发送和接收 MPI 一些常用函数
3 MPI 介绍 Message Passing Interface 消息传递编程标准, 目前最为通用的并行编程方式 提供一个高效 可扩展 统一的并行编程环境 MPI 是一个库, 不是一门语言,MPI 提供库函数 / 过程供 C/FORTRAN 调用 MPI 是一种标准或规范的代表而不特指某一个对它的具体实现 迄今为止所有的并行计算机制造商都提供对 MPI 的支持 MPI 是一种消息传递编程模型, 最终目的是服务于进程间通信这一目标
4 MPI 介绍 MPI 的目标 较高的通信性能 ; 较好的程序可移植性 ; 强大的功能 MPI 的实现 免费版本 1994 年公布 MPI 1.0 标准,1998 年公布 2.0 标准 MPI 1.0:MPICH MPI 2.0:MPICH MPI 商业版本 一些厂商也提供商业版的 MPI 系统, 许多是在 MPICH 的基础上优化产生的
5 MPI 下载与安装 MPICH 下载 MPICH 的安装 参考 MPICH Install Guide MPICH 的使用 参考 MPICH User Guide
6 MPI 编程基本概念 MPI 进程 MPI 程序中一个独立参与通信的个体 MPI 进程组 MPI 程序中由部分或全部进程构成的有序集合 每个进程都被赋予一个所在进程组中唯一的序号 (rank), 用于在该组中标识该进程, 称为进程号, 取值从 0 开始
7 MPI 进程与通信器 MPI 通信器 / 通信子 (Communicator) MPI 程序中进程间的通信必须通过通信器进行 通信器分为域内通信器 ( 同一进程组内的通信 ) 和域间通信器 ( 不同进程组的进程间的通信 ) MPI 程序启动时自动建立两个通信器 : MPI_COMM_WORLD : 包含程序中所有 MPI 进程 MPI_COMM_SELF : 有单个进程独自构成, 仅包含自己 MPI 程序中, 一个 MPI 进程由一个进程组和在该组中的进程号唯一确定 ; 或由一个通信器和在该通信器中的进程号唯一确定 进程号是相对进程组或通信器而言的, 同一进程在不同的进程组或通信器中可以有不同的进程号
8 MPI 消息 进程号是在进程组或通信器被创建时赋予的 空进程 :MPI_PROC_NULL 与空进程通信时不做任何操作 消息 (message) 一个消息指进程间进行的一次数据交换 一个消息由通信器 源地址 目的地址 消息标签 和数据构成
9 第一个 MPI Fortran 程序 program main include 'mpif.h' character * (MPI_MAX_PROCESSOR_NAME) proc_name integer myid, numprocs, namelen, rc, ierr call MPI_INIT( ierr ) call MPI_COMM_RANK( MPI_COMM_WORLD, myid, ierr ) call MPI_COMM_SIZE( MPI_COMM_WORLD, numprocs, ierr ) call MPI_GET_PROCESSOR_NAME(proc_name, namelen, ierr) write(*,10) myid, numprocs, proc_name 10 FORMAT('Hello, I am Proc. ',I2,' of ',I1,' on ', 20A) call MPI_FINALIZE(ierr) end mpif.h 是 MPI 相对于 FORTRAN 的头文件
10 MPI 程序分析 所有包含 MPI 调用的程序必须包含 MPI 头文件 MPI_MAX_PROCESSOR_NAME 是 MPI 预定义的宏, 即 MPI 所允许的机器名字的最大长度 MPI 程序的开始和结束必须是 MPI_INIT 和 MPI_FINALIZE, 分别完成 MPI 的初始化和结束工作 MPI_COMM_RANK 得到本进程的进程号 MPI_COMM_SIZE 得到所有参加运算的进程的个数 MPI_GET_PROCESSOR_NAME 得到运行本进程所在的结点的主机名 进程号取值范围为 0,, np-1
11 MPI 程序分析 在单个结点 (c1) 上, 开 4 个进程的运行结果 Hello, I am Proc. 1 of 4 on c1 Hello, I am Proc. 0 of 4 on c1 Hello, I am Proc. 2 of 4 on c1 Hello, I am Proc. 3 of 4 on c1 在四个结点上, 开 4 个进程的运行结果 Hello, I am Proc. 1 of 4 on c1 Hello, I am Proc. 0 of 4 on c2 Hello, I am Proc. 2 of 4 on c4 Hello, I am Proc. 3 of 4 on c3
12 MPI 程序执行过程 启动编译生成的可执行文件 hello 进程 0 进程 1 进程 2 进程 3 MPI_INIT MPI_COMM_RANK myid=0 MPI_GET_PROCESSOR_NAME proc_name=c1 namelen=2 Write hello, I am proc. 0 of 4 on c MPI_INIT MPI_COMM_RANK myid=4 MPI_GET_PROCESSOR_NAME proc_name=c1 namelen=2 Write hello, I am proc. 3 of 4 on c1 MPI_FINALIZE MPI_FINALIZE 程序运行结束
13 第一个 MPI C 程序 #include "mpi.h" #include <stdio.h> #include <math.h> mpi.h 是 MPI 相对于 C 语言的头文件 int main(argc,argv) int argc; char *argv[]; { int myid, np; int namelen; char proc_name[mpi_max_processor_name]; MPI_Init(&argc,&argv); MPI_Comm_rank(MPI_COMM_WORLD,&myid); MPI_Comm_size(MPI_COMM_WORLD,&numprocs); MPI_Get_processor_name(proc_name,&namelen); fprintf(stderr,"hello, I am proc. %d of %d on %s\n", myid, np, proc_name); MPI_Finalize(); }
14 MPI 编程的一些惯例 MPI 的所有常量 变量与函数 / 过程均以 MPI_ 开头 MPI 的 C 语言接口为函数,FORTRAN 接口为 SUBROUTINE, 且对应接口的名称相同 在 C 程序中, 所有常数的定义除下划线外一律由大写字母组成, 在函数和数据类型定义中, 接 MPI_ 之后的第一个字母大写, 其余全部为小写字母, 即 MPI_Xxxx_xxx 形式 对于 FORTRAN 程序,MPI 函数全部以过程方式调用, 一般全用大写字母表示, 即 MPI_XXXX_XXX 形式 (FORTRAN 不区分大小写 ) 除 MPI_WTIME 和 MPI_WTICK 外, 所有 C 函数调用之后都将返回一个错误信息码, 而 MPI 的所有 FORTRAN 子程序中都有一个哑元参数 (IERR) 代表错误码
15 MPI 编程的一些惯例 由于 C 语言的函数调用机制是值传递, 所以 MPI 的所有 C 函数中的输出参数用的都是指针 MPI 是按进程组 (Process Group) 方式工作 : 所有 MPI 程序在开始时均被认为是在通信器 MPI_COMM_WORLD 所拥有的进程组中工作, 之后用户可以根据自己的需要, 建立其它的进程组 所有 MPI 的通信一定要在通信器中进行 FORTRAN 的数组下标缺省以 1 开始, 而 C 语言的数组是以 0 开始
16 MPI 数据类型 MPI 除了提供 C 语言函数和 FORTRAN 子程序之外, 还定义了一组常量和 C 变量数据类型 MPI 常量命名规则 : 全部大写 MPI 变量数据类型命名规则 : 以 MPI_ 开头, 后面跟 C 语言或 FORTRAN 原始数据类型名称 MPI 数据类型 : 原始数据类型和自定义数据类型
17 MPI 原始数据类型 FORTRAN 77 数据类型 MPI datatype MPI_INTEGER MPI_REAL MPI_DOUBLE_PRECISION MPI_COMPLEX MPI_DOUBLE_COMPLEX MPI_LOGICAL MPI_CHARACTER MPI_BYTE MPI_PACKED Fortran datatype INTEGER REAL DOUBLE PRECISION COMPLEX DOUBLE COMPLEX LOGICAL CHARACTER(1)
18 MPI 原始数据类型 C MPI datatype MPI_CHAR MPI_SHORT MPI_INT MPI_LONG MPI_UNSIGNED_CHAR MPI_UNSIGNED_SHORT MPI_UNSIGNED_INT MPI_UNSIGNED_LONG MPI_FLOAT MPI_DOUBLE MPI_LONG_DOUBLE MPI_BYTE MPI_PACKED C datatype signed char signed short int signed int signed long int unsigned char unsigned short int unsigned int unsigned long int float double long double
19 MPI 原始数据类型 某些 MPI 系统还支持一些附加数据类型 附加的 MPI 数据类型 MPI_LONG_LONG_INT long 相应的 C 数据类型 long int 附加的 MPI 数据类型 MPI_REAL2 MPI_REAL4 MPI_REAL8 MPI_INTEGER1 MPI_INTEGER2 MPI_INTEGER4 相应的 FORTRAN77 数据类型 REAL*2 REAL*4 REAL*8 INTEGER*1 INTEGER*2 INTEGER*4
20 MPI 最常用的六个接口 MPI_INIT MPI_FINALIZE MPI_COMM_RANK MPI_COMM_SIZE MPI_SEND MPI_RECV
21 MPI_INIT MPI_INIT:MPI 初始化 参数 C F77 无 int MPI_Init(int *argc, char ***argv) MPI_INIT(IERR) INTEGER IERR 该函数初始化 MPI 并行程序的执行环境, 它必须在调用所有其它 MPI 函数 ( 除 MPI_INITIALIZED) 之前被调用, 并且在一个 MPI 程序中, 只能被调用一次
22 MPI_FINALIZE MPI_FINALIZE: 结束 MPI 系统 参数 C F77 无 int MPI_Finalize(void) MPI_FINALIZE(IERR) INTEGER IERR 该函数清除 MPI 环境的所有状态 即一但它被调用, 所有 MPI 函数都不能再调用, 其中包括 MPI_INIT
23 MPI_COMM_RANK MPI_COMM_RANK(comm, rank) 参数 C F77 IN comm 通信器 OUT rank 本进程在通信器 comm 中的进程号 int MPI_Comm_rank(MPI_Comm comm, int *rank) MPI_COMM_RANK(COMM, RANK, IERR) INTEGER COMM, RANK, IERR 该函数返回本进程在指定通信器中的进程号
24 MPI_COMM_SIZE MPI_COMM_SIZE(comm, size) 参数 C F77 IN comm 通信器 OUT size 该通信器 comm 中的进程数 int MPI_Comm_size(MPI_Comm comm, int *size) MPI_COMM_SIZE(COMM, SIZE, IERR) INTEGER COMM, SIZE, IERR 该函数返回指定通信器所包含的进程数
25 MPI_SEND 点对点通信 MPI_SEND(buf,count,datatype,dest,tag,comm) 参数 C F77 IN buf 所发送消息的首地址 IN count 将发送的数据的个数 IN datatype 发送数据的数据类型 IN dest 接收消息的进程的标识号 IN tag 消息标签 IN comm 通信器 int MPI_Send(void *buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm) MPI_SEND(BUF,COUNT,DATATYPE,DEST,TAG, COMM, IERR) <type> BUF(*) INTEGER COUNT,DATATYPE,DEST,TAG,COMM,IERR
26 MPI_SEND 点对点通信 MPI_SEND(buf,count,datatype,dest,tag,comm) 阻塞型消息发送接口 MPI_SEND 将缓冲区中 count 个 datatype 类型的数据发给进程号为 dest 的目的进程 这里 count 是元素个数, 即指定数据类型的个数, 不是字节数, 数据的起始地址为 buf 本次发送的消息标签是 tag, 使用标签的目的是把本次发送的消息和本进程向同一目的进程发送的其它消息区别开来 其中 dest 的取值范围为 0~np-1 ( np 表示通信器 comm 中的进程数 ) 或 MPI_PROC_NULL,tag 的取值为 0~ MPI_TAG_UB 该函数可以发送各种类型的数据, 如整型 实型 字符等 点对点通信是 MPI 通信机制的基础
27 MPI_RECV 点对点通信 MPI_RECV(buf,count,datatype,source,tag,comm,status) 参数 C F77 OUT buf 接收消息数据的首地址 IN count 接收数据的最大个数 IN datatype 接收数据的数据类型 IN source 发送消息的进程的标识号 IN tag 消息标签 IN comm 通信器 OUT status 返回状态 int MPI_Recv(void *buf, int count, MPI_Datatype datatype, int source, int tag,mpi_comm comm,mpi_status *status) MPI_RECV(BUF, COUNT, DATATYPE, SOURCE, TAG, COMM, STATUS, IERR) <type> BUF(*) INTEGER COUNT, DATATYPE, SOURCE, TAG, COMM, IERR, STATUS(MPI_STATUS_SIZE)
28 MPI_RECV 点对点通信 MPI_RECV(buf,count,datatype,source,tag,comm,status) 阻塞型消息接收接口 从指定的进程 source 接收不超过 count 个 datatype 类型的数据, 并把它放到缓冲区中, 起始位置为 buf, 本次消息的标识为 tag 这里 source 的取值范围为 0 ~np-1, 或 MPI_ANY_SOURCE, 或 MPI_PROC_NULL,tag 的取值为 0~MPI_TAG_UB 或 MPI_ANY_TAG 接收消息时返回的状态 STATUS, 在 C 语言中是用结构定义的, 在 FORTRAN 中是用数组定义的, 其中包括 MPI_SOURCE,MPI_TAG 和 MPI_ERROR 此外 STATUS 还包含接收消息元素的个数, 但它不是显式给出的, 需要用到后面给出的函数 MPI_GET_COUNT
29 MPI 程序示例 例 : 将每个进程中某个数据发送给下一个进程, 并从前一个进程接收一个数据, 即 0 号进程给 1 号进程发送一个数据, 并从 np-1 号进程接收一个数据,1 号进程从 0 号进程接收一个数据, 并向 2 号进程发送一个数据, 以此类推 实现方式一 : 0 号进程先发送后接收, 其它进程先接收后发送 例 :ex4sendrecv01.f, ex4sendrecv02.f 实现方式二 : 奇数号进程先发送后接收, 偶数号进程先接收后发送 上机作业 在使用阻塞型函数传递消息时要避免死锁!
30 MPI 发送接收 MPI_SEND(buf,count,datatype,dest,tag,comm) 消息数据 消息信封 MPI_RECV(buf,count,datatype,source,tag,comm,status) 消息数据 消息信封 发送数据类型 通信函数中的数据类型 接收的数据类型要一致! C: 结构 status.mpi_source status.mpi_tag status.mpi_error FORTRAN: 数组 status(mpi_source) status(mpi_tag) status(mpi_error)
31 发送与接收组合进行 MPI_SENDRECV(sendbuf, sendcount, sendtype, dest, sendtag, recvbuf, recvcount, recvtype, source, recvtag, comm, status) 参数略 C F77 int MPI_Sendrecv(void *sendbuf, int sendcount, MPI_Datatype sendtype, int dest, int sendtag, void *recvbuf, int recvcount, MPI_Datatype recvtype, int source, int recvtag, MPI_Comm comm, MPI_Status *status) MPI_SENDRECV(SENDBUF, SENDCOUNT, SENDTYPE, DEST, SENDTAG, RECVBUF, RECVCOUNT, RECVTYPE, SOURCE, RECVTAG, COMM, STATUS,IERR) <type> INTEGER SENDBUF(*), RECVBUF(*) SENDCOUNT, SENDTYPE, DEST, SENDTAG, RECVCOUNT, RECVTYPE, SOURCE, RECVTAG, COMM, IERR, STATUS(MPI_STATUS_SIZE)
32 MPI_SENDRECV MPI_SENDRECV(sendbuf, sendcount, sendtype, dest, sendtag, recvbuf, recvcount, recvtype, source, recvtag, comm, status) 这是发送消息和接收消息组合在一起的一个函数, 好处是不用考虑先发送还是先接收消息, 从而可以避免消息传递过程中的死锁 sendbuf 和 recvbuf 必须指向不同的缓冲区 例 :ex4sendrecv03.f
33 MPI_SENDRECV_REPLACE MPI_SENDRECV_REPLACE(buf, datatype, dest, sendtag, source, recvtag, comm, status) 功能与 MPI_SENDRECV 类似, 但收发消息使用的是同一个缓冲区 例 :ex4sendrecv04.f
34 MPI 程序示例 例 : 计算 π 的值 1 n 4 π = d x h f( x ) 0 2 i x + 1 采用等步长中矩形公式, 其中 n 为积分区间数,h = 1/n 为步长,x i = (i + 0.5) h 为积分区间的中点 假设采用 p 的进程同时计算, 各自计算其中的一部分, 然后再将结果加起来 i= 1 例 :ex4pi.f mpif77 -Wno-globals o ex4pi ex4pi.f
35 MPI_GET_COUNT MPI_GET_COUNT(status, datatype, count) 参数 C F77 IN status IN datatype 接收操作的返回状态接收操作使用的数据类型 OUT count 接收到的数据个数 int MPI_Get_count(MPI_Status *status, MPI_Datatype datatype, int *count) MPI_GET_COUNT(STATUS,DATATYPE,COUNT,IERR) INTEGER DATATYPE,COUNT,IERR, STATUS(MPI_STATUS_SIZE) 查询实际接收到的数据信息
36 MPI 异常终止 MPI_ABORT(comm, errorcode) 参数 IN comm OUT errorcode 通信器 错误码 C F77 int MPI_Abort(MPI_Comm comm,int errorcode) MPI_ABORT(COMM, ERRORCODE, IERR) INTEGER COMM, ERRORCODE, IERR 异常终止 MPI 程序的执行,MPI 系统会尽量设法终止通信器中的所有进程
37 MPI 计时函数 MPI_WTIME() 参数 C F77 无 double MPI_Wtime(void) DOUBLE PRECISION MPI_WTIME() 该函数返回当前的墙钟时间
38 MPI 计时函数 MPI_WTICK() 参数 C F77 无 double MPI_Wtick(void) DOUBLE PRECISION MPI_WTICK() 该函数返回 MPI_WTIME 的时钟精度, 单位为秒 MPI_WTIME 和 MPI_WTICK 是 C 中仅有的两个返回双精度值而非整型错误码的 MPI 函数 ; 它们也是 FORTRAN 中仅有的两个 FUNCTION 形式的接口!
39 获取结点主机名 MPI_GET_PROCESSOR_NAME(name, namelen) 参数 C F77 OUT name 结点主机名 OUT namelen 主机名的长度 int MPI_Get_processor_name(char *name, int *namelen) MPI_GET_PROCESSOR_NAME(NAME, NAMELEN, IERR) CHARACTER(*) NAME INTEGER NAMELEN, IERR 该函数返回进程所在结点的主机名
40 获取 MPI 版本号 MPI_MPI_GET_VERSION(version, subver) 参数 C F77 OUT version 主版本号 OUT subver 次版本号 int MPI_Get_version(int *version, int *subver ) MPI_GET_VERSION(VERSION, SUBVER, IERR) INTEGER VERSION, SUBVER, IERR 该函数返回 MPI 的版本号
Parallel Programming with MPI
MPI 并行编程入门 中国科学院计算机网络信息中心超级计算中心 参考材料 张林波清华大学出版社莫则尧科学出版社都志辉清华大学出版社 消息传递平台 MPI 什么是 MPI (Message Passing Interface) 是函数库规范, 而不是并行语言 ; 操作如同库函数调用 是一种标准和规范, 而非某个对它的具体实现 (MPICH 等 ), 与编程语言无关 是一种消息传递编程模型, 并成为这类编程模型的代表
消息传递并行编程环境MPI.doc
973 MPI PETS 8 15 8 16 8 17 MPI MPI MPI MPI 2 MPI PETS PETS 1 1971 7 1992 1997 1999 2 MPI MPI MPI 1 MPI MPI MPI 2 - u=f MPI 3 1 proess 1 2 2 CPU 4 send reeive barrier redution 1 2 3 CPU soket, 4 : API
模板
MPI MPI MPI MPI MPI MPI 4 18 9% 5 ? 6 ? 7 数 个数 数 个数 个数 个数 8 ccnuma; SMP MPP; Cluster 9 10 11 12 13 MPI MPI MPI MPI MPI? MPI MPI MPI MPI 15 MPI? MPI(Message Passing Interface ) 1994 5 MPI MPI MPI MPI C
Microsoft PowerPoint - Tongji_MPI编程初步
并行编程初步 张丹丹 上海超级计算中心 2011-3-4 提纲 引言 认识 MPI 编程 MPI 编程简介 实例 并行计算机体系架构 共享存储 (Shared Memory) 并行计算机体系架构 分布式存储 (Distributed Memory) 混合架构 (Hybrid) 并行计算机体系架构 并行编程模型 数据并行模型 相同的操作同时作用于不同的数据 共享变量模型 用共享变量实现并行进程间的通信
mpi
MPI I II MPI FORTRAN C MPI MPI C /FORTRAN MPI MPI MPI MPI MPI MPI-2 MPI-1 MPI-2 MPI MPI ...IX...XI... XII...XIV... XVII...1 1...2 1.1...2 1.1.1...2 1.1.2...3 1.2...4 1.3...5 2...6 2.1...6 2.2...7 2.3...8
第7章-并行计算.ppt
EFEP90 10CDMP3 CD t 0 t 0 To pull a bigger wagon, it is easier to add more oxen than to grow a gigantic ox 10t 0 t 0 n p Ts Tp if E(n, p) < 1 p, then T (n) < T (n, p) s p S(n,p) = p : f(x)=sin(cos(x))
Parallel Programming with MPI
MPI 并行编程入门 中国科学院计算机网络信息中心超级计算中心 聚合通信 定义 三种通信方式 聚合函数列表 同步 广播 收集 散发 全散发收集 归约 定义 communicator 1 3 4 5 0 2 一个通信器的所有进程参与, 所有进程都调用聚合通信函数 MPI 系统保证聚合通信函数与点对点调用不会混淆 聚合通信不需要消息标号 聚合通信函数都为阻塞式函数 聚合通信的功能 : 通信 同步 计算等
大綱介紹 MPI 標準介紹 MPI 的主要目標 Compiler & Run 平行程式 MPICH 程式基本架構 點對點通訊 函數介紹 集體通訊 函數介紹
MPI 平行程式設計 勁智數位科技股份有限公司 技術研發部林勝峰 [email protected] 大綱介紹 MPI 標準介紹 MPI 的主要目標 Compiler & Run 平行程式 MPICH 程式基本架構 點對點通訊 函數介紹 集體通訊 函數介紹 MPI (Message Passing Interface) Version1.0:June, 1994. Version1.1:June,
PowerPoint 演示文稿
机群应用开发 并行编程原理及程序设计 Parallel Programming: Fundamentals and Implementation 戴荣 dair@dawningcomcn 曙光信息产业有限公司 2008 年 7 月 2008 年 7 月 1 参考文献 黄铠, 徐志伟著, 陆鑫达等译 可扩展并行计算技术, 结构与编程 北京 : 机械工业出版社, P33~56,P227~237, 2000
PowerPoint 演示文稿
第六讲 消息传递编程接口 MPI 三 MPI 数据类型 1 MPI 数据类型 MPI 数据类型定义 MPI 数据类型的大小 上下界 域及相关函数 MPI 新数据类型的创建 提交与释放 MPI 数据的打包与解包 2 MPI 数据类型 MPI 原始数据类型 MPI 消息传递通常只能处理连续存放的同一类型的数据 MPI 自定义数据类型 如果需要发送或接收具有复杂结构的数据时, 可以使用自定义数据类型 使用自定义数据类型的好处
目录 第一章 MPI 简介 消息传递编程的相关概念 分布式内存 消息传输 进程 消息传递库 发送 / 接收 同步 / 异步 阻塞
神威蓝光 计算机系统 MPI 用户手册 国家超级计算济南中心 2011 年 03 月 目录 第一章 MPI 简介... 1 1.1 消息传递编程的相关概念... 2 1.1.1 分布式内存... 2 1.1.2 消息传输... 3 1.1.3 进程... 3 1.1.4 消息传递库... 3 1.1.5 发送 / 接收... 3 1.1.6 同步 / 异步... 3 1.1.7 阻塞通讯... 4
MPI实验.doc
MPI 实验手册 2014 年 5 月 实验环境说明 : 虚拟机 :Vmware Workstation 9 Linux 系统 :CentOS 6.3 每台机器上有 3 个未配置的虚拟机节点用于进行 MPI 环境配置实验, 有 3 个已配置好 的节点可以直接运行 MPI 程序 3 台已配置好的 Linux 虚拟机 IP 地址如下, 可以登录系统用 ifconfig 指令查看 node1 192.168.1.11
C/C++语言 - C/C++数据
C/C++ C/C++ Table of contents 1. 2. 3. 4. char 5. 1 C = 5 (F 32). 9 F C 2 1 // fal2cel. c: Convert Fah temperature to Cel temperature 2 # include < stdio.h> 3 int main ( void ) 4 { 5 float fah, cel ;
Microsoft PowerPoint - 07 派生数据类型
能源与动力工程学院 目录 派生类型 陈 斌 固有数据类型 数值型 (numerical) 整型 INTEGER 实型 REAL 复数型 COMPLEX 非数值型 字符型 CHARACTER 逻辑型 ( 布尔型 )LOGICAL 自定义数据类型 ( 派生类型, derived type) 派生类型是指用户利用 Fortran 系统内部类型, 如整型 实型 复数型 逻辑型 字符型等的组合自行创建出一个新的数据类型,
CC213
: (Ken-Yi Lee), E-mail: [email protected] 49 [P.51] C/C++ [P.52] [P.53] [P.55] (int) [P.57] (float/double) [P.58] printf scanf [P.59] [P.61] ( / ) [P.62] (char) [P.65] : +-*/% [P.67] : = [P.68] : ,
Slide 1
基本编译和纠错 吴宏文 [email protected] IBM STG Lab Services and Training 1 目录 AIX 上编译介绍 MPI 编译运行介绍 一般程序的纠错 2 一般编译过程 源文件 source 编译 目标文件 object 连接 可执行文件 exe 执行 3 一般编译过程 Unix 系统中, 可执行文件没有统一的后缀, 系统从文件的属性来区分可执行文件和丌可执行文件
C 1
C homepage: xpzhangme 2018 5 30 C 1 C min(x, y) double C // min c # include # include double min ( double x, double y); int main ( int argc, char * argv []) { double x, y; if( argc!=
科学计算的语言-FORTRAN95
科 学 计 算 的 语 言 -FORTRAN95 目 录 第 一 篇 闲 话 第 1 章 目 的 是 计 算 第 2 章 FORTRAN95 如 何 描 述 计 算 第 3 章 FORTRAN 的 编 译 系 统 第 二 篇 计 算 的 叙 述 第 4 章 FORTRAN95 语 言 的 形 貌 第 5 章 准 备 数 据 第 6 章 构 造 数 据 第 7 章 声 明 数 据 第 8 章 构 造
C++ 程式設計
C C 料, 數, - 列 串 理 列 main 數串列 什 pointer) 數, 數, 數 數 省 不 不, 數 (1) 數, 不 數 * 料 * 數 int *int_ptr; char *ch_ptr; float *float_ptr; double *double_ptr; 數 (2) int i=3; int *ptr; ptr=&i; 1000 1012 ptr 數, 數 1004
mpic_2002
C 語言 MPI 平行計算程式設計 編著 : 鄭守成 期 間 : 民國 91 年 1 月 1 日 電話 : (03) 5776085 x 305 E-mail : [email protected] 1 C 語言 MPI 平行計算程式設計...1 第一章 前言...4 1.1 MPI 平行計算軟體...5 1.2 國家高速電腦中心的平行計算環境...6 1.3 在 IBM SP2 上如何使用
mannal
高 性 能 集 群 计 算 机 使 用 说 明 书 版 本 1.0.8 高 性 能 计 算 研 究 组 编 2008 年 3 月 12 日 第 1 页 共 30 页 高 性 能 集 群 计 算 机... 1 使 用 说 明 书... 1 高 性 能 计 算 集 群 使 用 说 明... 3 1. 集 群 系 统 概 述... 3 2. 使 用 方 法... 5 1. 登 录 方 法... 5 2.MPI
1 Project New Project 1 2 Windows 1 3 N C test Windows uv2 KEIL uvision2 1 2 New Project Ateml AT89C AT89C51 3 KEIL Demo C C File
51 C 51 51 C C C C C C * 2003-3-30 [email protected] C C C C KEIL uvision2 MCS51 PLM C VC++ 51 KEIL51 KEIL51 KEIL51 KEIL 2K DEMO C KEIL KEIL51 P 1 1 1 1-1 - 1 Project New Project 1 2 Windows 1 3 N C test
Microsoft PowerPoint - 4. 数组和字符串Arrays and Strings.ppt [兼容模式]
Arrays and Strings 存储同类型的多个元素 Store multi elements of the same type 数组 (array) 存储固定数目的同类型元素 如整型数组存储的是一组整数, 字符数组存储的是一组字符 数组的大小称为数组的尺度 (dimension). 定义格式 : type arrayname[dimension]; 如声明 4 个元素的整型数组 :intarr[4];
FY.DOC
高 职 高 专 21 世 纪 规 划 教 材 C++ 程 序 设 计 邓 振 杰 主 编 贾 振 华 孟 庆 敏 副 主 编 人 民 邮 电 出 版 社 内 容 提 要 本 书 系 统 地 介 绍 C++ 语 言 的 基 本 概 念 基 本 语 法 和 编 程 方 法, 深 入 浅 出 地 讲 述 C++ 语 言 面 向 对 象 的 重 要 特 征 : 类 和 对 象 抽 象 封 装 继 承 等 主
chap07.key
#include void two(); void three(); int main() printf("i'm in main.\n"); two(); return 0; void two() printf("i'm in two.\n"); three(); void three() printf("i'm in three.\n"); void, int 标识符逗号分隔,
untitled
不 料 料 例 : ( 料 ) 串 度 8 年 數 串 度 4 串 度 數 數 9- ( ) 利 數 struct { ; ; 數 struct 數 ; 9-2 數 利 數 C struct 數 ; C++ 數 ; struct 省略 9-3 例 ( 料 例 ) struct people{ char name[]; int age; char address[4]; char phone[]; int
, 即 使 是 在 昏 暗 的 灯 光 下, 她 仍 然 可 以 那 么 耀 眼 我 没 有 地 方 去, 你 会 带 着 我 么 杜 晗 像 是 在 嘲 笑 一 般, 嘴 角 的 一 抹 冷 笑 有 着 不 适 合 这 个 年 龄 的 冷 酷 和 无 情, 看 着 江 华 的 眼 神 毫 无 温
爱 情 飞 过 苍 凉 / 作 者 :18758265241 1 红 色 格 子 的 旅 行 箱, 在 湿 漉 漉 地 上 发 出 刺 啦 刺 啦 的 声 音, 那 么 刺 耳, 就 像 是 此 刻 杜 晗 的 里 一 样, 烦 躁 而 不 安 就 这 样 走 出 来 了,18 年 禁 锢 自 己 的 地 方 就 在 身 后, 杜 晗 手 指 关 节 泛 白, 紧 紧 地 拉 着 旅 行 箱, 走
SDK 概要 使用 Maven 的用户可以从 Maven 库中搜索 "odps-sdk" 获取不同版本的 Java SDK: 包名 odps-sdk-core odps-sdk-commons odps-sdk-udf odps-sdk-mapred odps-sdk-graph 描述 ODPS 基
开放数据处理服务 ODPS SDK SDK 概要 使用 Maven 的用户可以从 Maven 库中搜索 "odps-sdk" 获取不同版本的 Java SDK: 包名 odps-sdk-core odps-sdk-commons odps-sdk-udf odps-sdk-mapred odps-sdk-graph 描述 ODPS 基础功能的主体接口, 搜索关键词 "odpssdk-core" 一些
Trilinos 简介 Trilinos 简介 卢朓 Trilinos 简介 卢朓 Trilinos 简介 Trilinos 简介 Trilinos 的安装和使用 Trilinos 简介 Trilinos 简介 Trilinos 的安装和使用 Trilinos 简介 Trilinos Epetra
Department of Science and Engineering Computing School of Mathematics School Peking University Department of Science and Engineering Computing School of Mathematics School Peking University August 14,
Microsoft Word - FPKLSC_21.docx
足 印 门 徒 训 练 课 程 儿 童 / 少 年 篇 ( 组 长 使 用 ) 第 21 课 帮 助 人 和 耶 稣 成 为 朋 友 足 印 : 耶 稣 想 我 们 带 朋 友 去 找 祂 欢 迎 (7 分 钟 ) 当 父 母 生 命 师 傅 和 孩 子 们 来 到 的 时 候, 请 热 情 地 欢 迎 他 们 每 一 个 人 鼓 励 一 位 年 轻 人 与 你 一 同 去 欢 迎 参 加 者 的
OOP with Java 通知 Project 2 提交时间 : 3 月 14 日晚 9 点 另一名助教 : 王桢 学习使用文本编辑器 学习使用 cmd: Power shell 阅读参考资料
OOP with Java Yuanbin Wu cs@ecnu OOP with Java 通知 Project 2 提交时间 : 3 月 14 日晚 9 点 另一名助教 : 王桢 Email: [email protected] 学习使用文本编辑器 学习使用 cmd: Power shell 阅读参考资料 OOP with Java Java 类型 引用 不可变类型 对象存储位置 作用域 OOP
C/C++ 语言 - 循环
C/C++ Table of contents 7. 1. 2. while 3. 4. 5. for 6. 8. (do while) 9. 10. (nested loop) 11. 12. 13. 1 // summing.c: # include int main ( void ) { long num ; long sum = 0L; int status ; printf
Guava学习之Resources
Resources 提供提供操作 classpath 路径下所有资源的方法 除非另有说明, 否则类中所有方法的参数都不能为 null 虽然有些方法的参数是 URL 类型的, 但是这些方法实现通常不是以 HTTP 完成的 ; 同时这些资源也非 classpath 路径下的 下面两个函数都是根据资源的名称得到其绝对路径, 从函数里面可以看出,Resources 类中的 getresource 函数都是基于
新・明解C言語入門編『索引』
!... 75!=... 48 "... 234 " "... 9, 84, 240 #define... 118, 213 #include... 148 %... 23 %... 23, 24 %%... 23 %d... 4 %f... 29 %ld... 177 %lf... 31 %lu... 177 %o... 196 %p... 262 %s... 242, 244 %u... 177
目录 1 IPv6 快速转发 IPv6 快速转发配置命令 display ipv6 fast-forwarding aging-time display ipv6 fast-forwarding cache ipv6 fas
目录 1 IPv6 快速转发 1-1 1.1 IPv6 快速转发配置命令 1-1 1.1.1 display ipv6 fast-forwarding aging-time 1-1 1.1.2 display ipv6 fast-forwarding cache 1-1 1.1.3 ipv6 fast-forwarding aging-time 1-3 1.1.4 ipv6 fast-forwarding
Microsoft PowerPoint - 5. 指针Pointers.ppt [兼容模式]
指针 Pointers 变量指针与指针变量 Pointer of a variable 变量与内存 (Variables and Memory) 当你声明一个变量时, 计算机将给该变量一个内存, 可以存储变量的值 当你使用变量时, 计算机将做两步操作 : - 根据变量名查找其对应的地址 ; - 通过地址对该地址的变量内容进行读 (retrieve) 或写 (set) 变量的地址称为变量的指针! C++
OOP with Java 通知 Project 4: 5 月 2 日晚 9 点
OOP with Java Yuanbin Wu cs@ecnu OOP with Java 通知 Project 4: 5 月 2 日晚 9 点 复习 类的复用 组合 (composition): has-a 关系 class MyType { public int i; public double d; public char c; public void set(double x) { d =
Generated by Unregistered Batch DOC TO PDF Converter , please register! 浙江大学 C 程序设计及实验 试题卷 学年春季学期考试时间 : 2003 年 6 月 20 日上午 8:3
浙江大学 C 程序设计及实验 试题卷 2002-2003 学年春季学期考试时间 : 2003 年 6 月 20 日上午 8:30-10:30 注意 : 答题内容必须写在答题卷上, 写在本试题卷上无效 一. 单项选择题 ( 每题 1 分, 共 10 分 ) 1. 下列运算符中, 优先级最低的是 A.
Microsoft PowerPoint - CEM-07-Parallel.pptx
Parallel Scientific Computing by Computer Cluster Jiun-Hwa Lin Department of Electrical Engineering National Taiwan Ocean University Outline Introduction Simple Cluster Setup Real Examples at NTOU Conclusions
OOP with Java 通知 Project 4: 4 月 19 日晚 9 点
OOP with Java Yuanbin Wu cs@ecnu OOP with Java 通知 Project 4: 4 月 19 日晚 9 点 复习 类的复用 组合 (composition): has-a 关系 class MyType { public int i; public double d; public char c; public void set(double x) { d
untitled
MODBUS 1 MODBUS...1 1...4 1.1...4 1.2...4 1.3...4 1.4... 2...5 2.1...5 2.2...5 3...6 3.1 OPENSERIAL...6 3.2 CLOSESERIAL...8 3.3 RDMULTIBIT...8 3.4 RDMULTIWORD...9 3.5 WRTONEBIT...11 3.6 WRTONEWORD...12
3.1 num = 3 ch = 'C' 2
Java 1 3.1 num = 3 ch = 'C' 2 final 3.1 final : final final double PI=3.1415926; 3 3.2 4 int 3.2 (long int) (int) (short int) (byte) short sum; // sum 5 3.2 Java int long num=32967359818l; C:\java\app3_2.java:6:
NOWOER.OM m/n m/=n m/n m%=n m%n m%=n m%n m/=n 4. enum string x1, x2, x3=10, x4, x5, x; 函数外部问 x 等于什么? 随机值 5. unsigned char *p1; unsigned long *p
NOWOER.OM /++ 程师能 评估. 单项选择题 1. 下 描述正确的是 int *p1 = new int[10]; int *p2 = new int[10](); p1 和 p2 申请的空间 的值都是随机值 p1 和 p2 申请的空间 的值都已经初始化 p1 申请的空间 的值是随机值,p2 申请的空间 的值已经初始化 p1 申请的空间 的值已经初始化,p2 申请的空间 的值是随机值 2.
1 2032.1.16, 6:01 AM 2 2032.1.16, 6:01 AM 3 2032.1.16, 6:01 AM ( ) 4 2032.1.16, 6:01 AM 5 2032.1.16, 6:01 AM 6 2032.1.16, 6:01 AM 9 2032.1.16, 6:01 AM 10 2032.1.16, 6:02 AM 1 1 2009 7 2 3 2 2009 7 1
51 C 51 isp 10 C PCB C C C C KEIL
http://wwwispdowncom 51 C " + + " 51 AT89S51 In-System-Programming ISP 10 io 244 CPLD ATMEL PIC CPLD/FPGA ARM9 ISP http://wwwispdowncom/showoneproductasp?productid=15 51 C C C C C ispdown http://wwwispdowncom
2013 C 1 # include <stdio.h> 2 int main ( void ) 3 { 4 int cases, a, b, i; 5 scanf ("%d", & cases ); 6 for (i = 0;i < cases ;i ++) 7 { 8 scanf ("%d %d
2013 18 ( ) 1. C pa.c, pb.c, 2. C++ pa.cpp, pb.cpp, Compilation Error cin scanf Time Limit Exceeded 1: A 5 B 5 C 5 D 5 E 5 F 5 1 2013 C 1 # include 2 int main ( void ) 3 { 4 int cases, a, b,
新版 明解C++入門編
511!... 43, 85!=... 42 "... 118 " "... 337 " "... 8, 290 #... 71 #... 413 #define... 128, 236, 413 #endif... 412 #ifndef... 412 #if... 412 #include... 6, 337 #undef... 413 %... 23, 27 %=... 97 &... 243,
地 理 志 鏡 止 煞, 來 達 到 安 宅 的 效 果 4. 門 神 符 紙 : 於 門 板 繪 製 門 神, 作 為 宅 第 的 守 護, 民 宅 所 使 用 的 門 神 題 材, 多 為 天 官 賜 福 或 文 武 官 員 符 紙 是 以 畫 了 符 咒 的 紙 懸 掛 室 內, 或 加 框
第 二 篇 - 人 文 地 理 ( 五 ) 民 宅 的 祈 福 辟 邪 物 臺 灣 早 期 移 民, 因 為 離 鄉 背 井, 對 於 新 環 境 的 陌 生, 以 及 生 存 的 不 容 易, 再 加 上 承 襲 閩 粵 地 區 的 習 慣, 所 以 住 屋 講 究 的 是 祈 福 辟 邪 除 了 建 屋 之 前 要 看 地 理 風 水, 在 建 屋 時 更 有 許 多 禁 忌 要 遵 守 另 外,
帝国CMS下在PHP文件中调用数据库类执行SQL语句实例
帝国 CMS 下在 PHP 文件中调用数据库类执行 SQL 语句实例 这篇文章主要介绍了帝国 CMS 下在 PHP 文件中调用数据库类执行 SQL 语句实例, 本文还详细介绍了帝国 CMS 数据库类中的一些常用方法, 需要的朋友可以参考下 例 1: 连接 MYSQL 数据库例子 (a.php)
C
C 2017 4 1 1. 2. while 3. 4. 5. for 6. 2/161 C 7. 8. (do while) 9. 10. (nested loop) 11. 12. 3/161 C 1. I 1 // summing.c: 2 #include 3 int main(void) 4 { 5 long num; 6 long sum = 0L; 7 int status;
mvc
Build an application Tutor : Michael Pan Application Source codes - - Frameworks Xib files - - Resources - ( ) info.plist - UIKit Framework UIApplication Event status bar, icon... delegation [UIApplication
Microsoft PowerPoint - C语言课件-9-结构体.pptx
第九章结构体 郎大鹏 第九章结构体 9.1 结构体类型的声明方法 9.2 结构体类型变量的定义与使用 9.3 结构体数组 9.4 编程举例 9.5 习题 9.1 结构体类型的声明方法 结构体声明的语法形式如下 : struct 结构体标识符 成员变量列表 ; }; 例如, 为了描述班级 ( 假设仅仅包括班级编号 专业 人数等信息 ), 可以声明如下的结构体类型 struct Class char Code[10];
C 1 # include <stdio.h> 2 int main ( void ) { 4 int cases, i; 5 long long a, b; 6 scanf ("%d", & cases ); 7 for (i = 0;i < cases ;i ++) 8 { 9
201 201 21 ( ) 1. C pa.c, pb.c, 2. C++ pa.cpp, pb.cpp Compilation Error long long cin scanf Time Limit Exceeded 1: A 1 B 1 C 5 D RPG 10 E 10 F 1 G II 1 1 201 201 C 1 # include 2 int main ( void
epub 33-8
8 1) 2) 3) A S C I I 4 C I / O I / 8.1 8.1.1 1. ANSI C F I L E s t d i o. h typedef struct i n t _ f d ; i n t _ c l e f t ; i n t _ m o d e ; c h a r *_ n e x t ; char *_buff; /* /* /* /* /* 1 5 4 C FILE
目录 1 IPv6 快速转发 IPv6 快速转发配置命令 display ipv6 fast-forwarding aging-time display ipv6 fast-forwarding cache ipv6 fas
目录 1 IPv6 快速转发 1-1 1.1 IPv6 快速转发配置命令 1-1 1.1.1 display ipv6 fast-forwarding aging-time 1-1 1.1.2 display ipv6 fast-forwarding cache 1-1 1.1.3 ipv6 fast-forwarding aging-time 1-3 1.1.4 ipv6 fast-forwarding
untitled
A, 3+A printf( ABCDEF ) 3+ printf( ABCDEF ) 2.1 C++ main main main) * ( ) ( ) [ ].* ->* ()[] [][] ** *& char (f)(int); ( ) (f) (f) f (int) f int char f char f(int) (f) char (*f)(int); (*f) (int) (
BOOL EnumWindows(WNDENUMPROC lparam); lpenumfunc, LPARAM (Native Interface) PowerBuilder PowerBuilder PBNI 2
PowerBuilder 9 PowerBuilder Native Interface(PBNI) PowerBuilder 9 PowerBuilder C++ Java PowerBuilder 9 PBNI PowerBuilder Java C++ PowerBuilder NVO / PowerBuilder C/C++ PowerBuilder 9.0 PowerBuilder Native
nooog
C : : : , C C,,, C, C,, C ( ), ( ) C,,, ;,, ; C,,, ;, ;, ;, ;,,,, ;,,, ; : 1 9, 2 3, 4, 5, 6 10 11, 7 8, 12 13,,,,, 2008 1 1 (1 ) 1.1 (1 ) 1.1.1 ( ) 1.1.2 ( ) 1.1.3 ( ) 1.1.4 ( ) 1.1.5 ( ) 1.2 ( ) 1.2.1
Microsoft Word - 物件導向編程精要.doc
Essential Object-Oriented Programming Josh Ko 2007.03.11 object-oriented programming C++ Java OO class object OOP Ruby duck typing complexity abstraction paradigm objects objects model object-oriented
6 1 147 3 1911 3 10 4 9 1 2 3 4 5 6 14 13 5 148 1 1910 10 13 2 21 18 9 19 7 4 3 11 7 20 3 5 1 5 1 16 6 18 17 5 1 7 12 30 149 10 7 13 4 15 19 13 8 26 14 7 1 3 17 17 10 3 8 37 17 10 10 20 17 1 3 12 17 12
Microsoft PowerPoint - multicore curriculum of sspku.ppt
Curriculum Development for Multi-core Software Technology at Peking University Prof. Zhonghai Wu School of Software and Microelectronics Peking University http://www.ss.pku.edu.cn/multicore August 2008
untitled
料 2-1 料 料 x, y, z 料 不 不 料濾 料 不 料 料 不 料 錄 料 2-1 a 料 2-1 b 2003 a 料 b 料 2-1 料 2003 料 料 行 料濾 料亂 濾 料 料 滑 料 理 料 2001 料 兩 理 料 不 TIN, Triangular Irregular Network 8 2-2 a 數 量 料 便 精 2003 料 行 理 料 立 狀 連 料 狀 立 料
JLX
PRODUCT:LCD MODULE. Model No.: JLX177-006 Product Type: 1.77 inch QVGA TFT Modoule. 产品规格书 晶联讯研发研发部 : Written By Checked By Approved By 客户名称 : 结构电子核准 地址 : 深圳市宝安区西乡宝安大道东华工业区 A3 栋 6 楼电话 :0755-29784961 Http://www.jlxlcd.cn
<4D6963726F736F667420576F7264202D20482E323634B5F8B054BD73BD58A4A7A5ADA6E6A4C6ACE3A8732E646F63>
H.264 視 訊 編 碼 之 平 行 化 研 究 專 題 學 生 : 廖 友 誌 陳 彥 豪 指 導 教 授 : 李 良 德 教 授 大 同 大 學 資 訊 工 程 學 系 專 題 報 告 中 華 民 國 九 十 七 年 六 月 摘 要 H.264 是 新 一 代 的 視 訊 壓 縮 標 準, 它 提 供 了 更 高 的 壓 縮 效 能, 使 壓 縮 品 質 進 一 步 的 提 升, 也 使 得
概述
OPC Version 1.6 build 0910 KOSRDK Knight OPC Server Rapid Development Toolkits Knight Workgroup, eehoo Technology 2002-9 OPC 1...4 2 API...5 2.1...5 2.2...5 2.2.1 KOS_Init...5 2.2.2 KOS_InitB...5 2.2.3
《C语言程序设计》第2版教材习题参考答案
教材 C 语言程序设计 ( 第 2 版 ) 清华大学出版社, 黄保和, 江弋编著 2011 年 10 月第二版 ISBN:978-7-302-26972-4 售价 :35 元 答案版本 本习题答案为 2012 年 2 月修订版本 一 选择题 1. 设已定义 int a, * p, 下列赋值表达式中正确的是 :C)p = &a A. *p = *a B. p = *a C.p = &a D. *p =
C PICC C++ C++ C C #include<pic.h> C static volatile unsigned char 0x01; static volatile unsigned char 0x02; static volatile unsigned cha
CYPOK CYPOK 1 UltraEdit Project-->Install Language Tool: Language Suite----->hi-tech picc Tool Name ---->PICC Compiler Executable ---->c:hi-picinpicc.exe ( Command-line Project-->New Project-->File Name--->myc
《计算概论》课程 第十九讲 C 程序设计语言应用
计算概论 A 程序设计部分 字符数组与字符串 李戈 北京大学信息科学技术学院软件研究所 [email protected] 字符数组的定义 #include int main() char a[10] = 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j' ; for (int i = 0; i < 10; i++) cout
目 录(目录名)
目录 目录...1-1 1.1 域名解析配置命令... 1-1 1.1.1 display dns domain... 1-1 1.1.2 display dns dynamic-host... 1-1 1.1.3 display dns server... 1-2 1.1.4 display ip host... 1-3 1.1.5 dns domain... 1-4 1.1.6 dns resolve...
Microsoft Word - 魔术师
魔 术 师 编 著 : 1 序 曲 八 年 前 缩 在 那 间 垂 着 厚 厚 窗 帘 的 阴 暗 房 间 的 阴 暗 角 落, 他 低 着 头 不 让 别 人 看 到 在 他 脸 上 疯 狂 纵 横 的 泪 水, 拼 命 祈 祷 拜 托 求 你 这 一 切 都 不 是 真 的 这 都 是 我 在 做 梦, 一 个 噩 梦 请 你 让 我 赶 快 醒 来, 让 我 摆 脱 这 个 噩 梦 求 你 了
