您当前的位置:首页 > 美文欣赏 > 内容

计算机二级C语言考试内容有那些?汇编语言常用指令

汇编语言常用指令单片机汇编语言汇编错误原因分析汇编语言的指令格式,目前有两种不同的标准:Windows下的汇编语言基本上都遵循Intel风格的语法,比如:MASM、NASM;而Unix/Linux下的汇编语言基本上都遵循AT&T风格的语法;一、汇编语言语句的通用格式[名称[:]] 指令码 [第一操作数][,第二操作数] ;注释汇编语言的指令码的操作数的个数可以是0、1、2个;当操作数的个数为2的时候,语句还有两种不同的格式:Windows下Intel风格的汇编语言语句格式为:[名称[:]] 指令码 目的操作数DST,源操作数SRC ;注释Unix/Linux下AT&T风格的汇编语言语句格式为:[名称[:]] 指令码 源操作数SRC,目的操作数DST ;注释例如: CYCLE: ADD AX,02H ;(AX)汇编语言语句格式中的“名称“并不是所有语句都必需的,但是,如果语句中带有“名称“,那么,大多数情况下,“名称“都表示的是内存中某一存储单元的地址,也就是“名称“后面各项在内存中存放的第一个存储单元的地址(包括该“名称“所在段的段地址和段内偏移地址);比如上面的指令中,CYCLE就是该语句的名称,CYCLE表示的就是其后面的机器指令码在内存中存放的第一个地址;“名称“与指令码之间的分隔符可以是冒号“:“,也可以是空格字符“ “;当以冒号分割时,该名称代表的是一个标号;当以空格分割时,该名称代表的可能是标号,也可能是变量;当指令码有多个操作数的时候,相邻两个操作数之间要用逗号“,“分割;指令码与操作数之间必须以空格分割;汇编语言语句的注释必须以分号“;“开头;二、组成语句的元素1、常数:汇编语言中的常数有整数、字符串;二进制、八进制、十进制、十六进制;汇编语言采用不同的后缀区分:B:二进制数; O:八进制数; D:十进制数; H:十六进制数;当一个数值后面没有后缀的时候,默认为十进制数;字符串常数是用一对单引号(’’)括起来的一串字符;2、表达式:由操作数和操作符组成;算数运算操作符: +、-、*、/、MOD,等;取模运算MOD是取两数相除的余数;逻辑运算操作符: AND(逻辑与)、OR(逻辑或)、NOT(逻辑非)、XOR(逻辑异或);注意:逻辑运算符同时又可以是逻辑运算指令的指令码,只有当它们出现在指令的操作数部分时,才是操作符;例如:ADD AL,0CH ADD 0FH ;第一个ADD是指令码,第二个ADD是操作符;关系运算操作符: EQ(相等)、NE(不等)、LT(小于)、GT(大于)、LE(小于等于)、GE(大于等于);汇编语言中的表达式不能单独构成语句,只能是语句的组成部分;注意:语句中表达式的求值不是在语句执行时完成的,而是在对源程序进行汇编链接时完成的.所以,语句中各表达式的值必须在汇编或链接时就是确定的,也就是说,表达式中各标识符的值在汇编或链接时就应该是确定的;3、标号:标号是由标识符表示的指令的名称,用于指示对应指令的位置(地址);标号具有三个属性:段地址、偏移地址和类型;标号的段地址和偏移地址属性是指该标号所对应的指令所在段的段地址和段内偏移地址;标号的类型有两种:NEAR和FAR;标号定义成NEAR类型,表示该标号在段内使用,而定义成FAR类型则表示该标号可以在段间使用;标号的定义:在指令码前面加上标识符和冒号“:“;例如:START: PUSH DS这条语句里面,START就是我们定义的标号,它代表指令PUSH的地址,所以,标号可以作为程序转移指令的操作数(即:要转向的地址);标号还可以采用伪指令来定义;例如:用LABEL伪指令和过程定义伪指令来定义;4、变量:与高级语言一样,并不是所有的操作数都是常数,汇编语言也有自己的变量,变量的值在程序运行期间是可以被改变的;A.定义变量:汇编语言中,变量的定义是通过伪指令来完成的;定义变量的伪指令格式如下:变量名 DB 表达式 ;定义字节变量,又称单字节变量(1个连续字节),DB--》BYTE变量名 DW 表达式 ;定义字变量,又称双字节变量(2个连续字节),DW--》WORD变量名 DD 表达式 ;定义双字变量,又称四字节变量(4个连续字节),DD--》DWORD变量名 DF 表达式 ;定义六字节变量,又称六字节变量(6个连续字节),DF--》FWORD变量名 DQ 表达式 ;定义长字变量,又称八字节变量(8个连续字节),DQ--》QWORD变量名 DT 表达式 ;定义十字节变量(10个连续字节),DT--》TBYTE;其中,变量名是一个合法的标识符,变量名后面不能加冒号“:“,只能用空格;变量名不是必要的,可有可无;变量的类型由关键字DB、DW、DD、DQ、DT来定义;变量定义语句中的“表达式“是用于对变量进行初始化的,可有一下几种情况:(1).一个或多个常数或表达式;当为多个常数或表达式时,期间要用逗号隔开;如DATA1--DATA4;(2).带单引号的字符串;对于字节型(DB)变量,每个变量的大小为1个字节,每个变量的值不能超过1个字符,每个字节内存入一个字符的ASCII码值,整个字符串可以在同一对单引号内给出,这相当于是定义了一个字符数组,如DATA5;对于字类型(DW)变量,每个变量的大小为2个字节,每个变量的值不能超过2个字符,若为2个字符时,同样遵循高位存入高字节,低位存入低字节的规则;若为1个字符,则该字符的ASCII码值存入到低字节,高字节为00,如DATA6;对于双字类型(DD)变量,每个变量的大小为4个字节,每个变量的值不能超过2个字符,若为2个字符,同样遵循高位存入高字节,低位存入低字节的规则;但是2个字符的值被存入到双字变量的最低2个字节中,1个字符的值被存入到双字变量的最低1个字节中;对于长字类型(DQ)变量,每个变量的大小为8个字节,每个变量的值不能超过2个字符,若为2个字符,同样遵循高位存入高字节,低位存入低字节的规则;但是2个字符的值被存入到长字变量的最低2个字节中,1个字符的值被存入到长字变量的最低1个字节中;(3).一个问号“?“,表示该变量的值不确定,即:该变量所表示的内存单元中的内容是不确定的,或者说是,当表达式为问号时,变量所对应的内存区中并没有存入新的值,而只是预留出了相应的存储空间;如DATA7、DATA8(4).重复方式;此时的格式为: 重复次数 DUP(表达式);重复方式指出表达式的值可以重复地存储到变量对应的内存区中,重复的次数由伪指令给出,相当于定义数组;如DATA9、DATA10定义变量的例子:DATA1 DB 20H ;1字节变量DATA2 DW 0204H,1000H ;2字节变量DATA3 DB (-1*3),(15/3) ;1字节变量DATA4 DD 123456H ;4字节变量DATA5 DB ’0123’ ;字符串变量,相当于一个字符数组DATA6 DW ’AB’,’C’,’D’ ;字符串变量,相当于一个字符串数组;DATA7 DB ? ;1字节变量,未初始化DATA8 DD ? ;4字节变量,未初始化DATA9 DB 5 DUP(0) ;1字节变量,用5个0初始化,相当于是一个具有5个DB型元素的数组DATA10 DW 3 DUP(?) ;2字节变量,未初始化,相当于是一个具有3个DW型元素的数组变量定义语句中伪指令的功能是在变量名所对应的地址开始的内存区依次存入表达式中的各项值,表达式中的每项值所占用内存字节数与变量的类型对应;总结:一个变量的变量名实际上就代表了该变量所对应的内存区在内存段中的有效地址(偏移地址);高地址是指地址值相对较大,低地址是指地址值相对较小,高地址与低地址是相对而言的;5、变量的属性:(1).属性介绍一个变量具有一下属性:A.段地址(SEG):变量所在段的段地址;B.偏移地址(OFFSET):变量所在段内的偏移地址;C.类型(TYPE):变量的类型定义了每个变量所占用的内存字节数,对于DB、DW、DD、DQ、DT类型定义的变量所占用的内存字节数分别是1、2、4、8、10;通常又将DB、DW、DD类型所定义的变量分别成为BYTE类型、WORD类型、DWORD类型变量;常用标识符的类型值列表:标识符种类 字节变量 字变量 双字变量 近标号NEAR 远标号FARTYPE的值 1 2 4 -1 -2D.长度(LENGTH):变量定义时,一个变量名所定义的变量个数;在含有DUP操作符的变量定义中,变量名所定义的变量个数为定义格式中的重复次数;在其它各种变量定义中,每个变量名所定义的变量个数均为1个;E.大小(SIZE):变量定义语句中,分配给同一个变量名的所有变量的总的字节数,其值为该变量的类型与长度的成绩;其中,段地址、偏移地址和类型属性是变量的主属性,而长度和大小属性是变量的辅助属性;(2).属性操作符:操作符 表达式 含义SEG SEG 变量名或标号 取出变量名或标号所在段的段地址OFFSET OFFSET 变量名或标号 取出变量名或标号所在段内的偏移地址TYPE TYPE 变量名或标号 取出变量名或标号的类型(变量所占用的字节数)LENGTH LENGTH 变量名 取出变量的长度SIZE SIZE 变量名 取出变量的大小这些操作符不能单独构成语句,只能作为表达式的组成部分,并且表达式的求值也是在汇编过程中完成的;6.强制类型转换操作符PTR格式:数据类型 PTR 地址表达式格式中的“数据类型“可以是BYTE、WORD、DWORD、NEAR、FAR;前三种类型是变量的类型,后两种类型是标号的类型;格式中的表达式可以是变量、标号、其它地址表达式;PTR操作符的功能是用来重新定义已定义的变量或标号的类型,其作用域只在当前语句中; 例如:DATA1 DW 02HMOV BYTE PTR DATA1,AL这条指令中,是把DATA1的类型转换为BYTE类型,然后把AL中的内容存放到DATA1的最低一个字节中;作用域只在这条MOV语句中,过了这条语句,DATA1仍然是DW类型,即:DATA1原来的类型并没有被修改;怎么用C语言求二分法二分法查找有一个前提,汇编语言指令有哪些一、数据位传送指令:1、MOV   C,  bit,(bit) ← 1 三、位变量逻辑指令:ANL   C,   bit    ANL   C,   bit    ORL   C,   bit   ORL   C,   bit延展阅读:汇编指令是汇编语言中使用的一些操作符和助记符,还包括一些伪指令(如assume,end),11、XCHG 交换字或字节( 至少有一个操作数为寄存器,段寄存器不可作为操作数),无值类型)及其定义方法以及C运算符的种类、运算优先级和结合性等,考核内容包括计算机语言与基础程序设计能力,C    进位位 (bit) ← C 二、位变量修改指令:1、CLR    C          ; 将C=02、CLR    bit3、CPL    C           ; 将C求反再存入C4、CPL    bit          ; 将bit求反再存入bit5、SETB   C          ; 将C=16、SETB   bit,函数的定义方法、正确调用。

计算机二级C语言考试内容有那些

二级计算机是国家计算机等级考试的一部分,主要考察的是C语言的计算机编程能力。考核内容包括计算机语言与基础程序设计能力,要求参试者掌握一门计算机语言。具体考点如下:1、C语言程序的结构。需重点了解程序的构成,main函数和其他函数,源程序的书写格式。2、数据类型及其运算。包括C的数据类型(基本类型,构造类型,指针类型,无值类型)及其定义方法以及C运算符的种类、运算优先级和结合性等。3、基本语句。需要了解掌握表达式语句,空语句,复合语句。以及输入输出函数的调用,正确输入数据并正确设计输出格式等。4、选择结构程序设计,各类语句以及选择结构嵌套。5、循环结构程序设计,理解各类循环、语句以及循环的嵌套。6、会一维数组和二维数组的定义、初始化和数组元素的引用。7、库函数的正确调用,函数的定义方法、正确调用。8、文件操作,如文件的打开、关闭、读写、定位。9、地址与指针变量的概念,地址运算符与间址运算符。10、结构体与共同体。11、位运算符的含义和使用。12、编译预处理等。

汇编语言常用指令

单片机汇编语言汇编错误原因分析汇编语言的指令格式,目前有两种不同的标准:Windows下的汇编语言基本上都遵循Intel风格的语法,比如:MASM、NASM;而Unix/Linux下的汇编语言基本上都遵循AT&T风格的语法;一、汇编语言语句的通用格式[名称[:]] 指令码 [第一操作数][,第二操作数] ;注释汇编语言的指令码的操作数的个数可以是0、1、2个;当操作数的个数为2的时候,语句还有两种不同的格式:Windows下Intel风格的汇编语言语句格式为:[名称[:]] 指令码 目的操作数DST,源操作数SRC ;注释Unix/Linux下AT&T风格的汇编语言语句格式为:[名称[:]] 指令码 源操作数SRC,目的操作数DST ;注释例如: CYCLE: ADD AX,02H ;(AX)汇编语言语句格式中的“名称“并不是所有语句都必需的,但是,如果语句中带有“名称“,那么,大多数情况下,“名称“都表示的是内存中某一存储单元的地址,也就是“名称“后面各项在内存中存放的第一个存储单元的地址(包括该“名称“所在段的段地址和段内偏移地址);比如上面的指令中,CYCLE就是该语句的名称,CYCLE表示的就是其后面的机器指令码在内存中存放的第一个地址;“名称“与指令码之间的分隔符可以是冒号“:“,也可以是空格字符“ “;当以冒号分割时,该名称代表的是一个标号;当以空格分割时,该名称代表的可能是标号,也可能是变量;当指令码有多个操作数的时候,相邻两个操作数之间要用逗号“,“分割;指令码与操作数之间必须以空格分割;汇编语言语句的注释必须以分号“;“开头;二、组成语句的元素1、常数:汇编语言中的常数有整数、字符串;二进制、八进制、十进制、十六进制;汇编语言采用不同的后缀区分:B:二进制数; O:八进制数; D:十进制数; H:十六进制数;当一个数值后面没有后缀的时候,默认为十进制数;字符串常数是用一对单引号(’’)括起来的一串字符;2、表达式:由操作数和操作符组成;算数运算操作符: +、-、*、/、MOD,等;取模运算MOD是取两数相除的余数;逻辑运算操作符: AND(逻辑与)、OR(逻辑或)、NOT(逻辑非)、XOR(逻辑异或);注意:逻辑运算符同时又可以是逻辑运算指令的指令码,只有当它们出现在指令的操作数部分时,才是操作符;例如:ADD AL,0CH ADD 0FH ;第一个ADD是指令码,第二个ADD是操作符;关系运算操作符: EQ(相等)、NE(不等)、LT(小于)、GT(大于)、LE(小于等于)、GE(大于等于);汇编语言中的表达式不能单独构成语句,只能是语句的组成部分;注意:语句中表达式的求值不是在语句执行时完成的,而是在对源程序进行汇编链接时完成的.所以,语句中各表达式的值必须在汇编或链接时就是确定的,也就是说,表达式中各标识符的值在汇编或链接时就应该是确定的;3、标号:标号是由标识符表示的指令的名称,用于指示对应指令的位置(地址);标号具有三个属性:段地址、偏移地址和类型;标号的段地址和偏移地址属性是指该标号所对应的指令所在段的段地址和段内偏移地址;标号的类型有两种:NEAR和FAR;标号定义成NEAR类型,表示该标号在段内使用,而定义成FAR类型则表示该标号可以在段间使用;标号的定义:在指令码前面加上标识符和冒号“:“;例如:START: PUSH DS这条语句里面,START就是我们定义的标号,它代表指令PUSH的地址,所以,标号可以作为程序转移指令的操作数(即:要转向的地址);标号还可以采用伪指令来定义;例如:用LABEL伪指令和过程定义伪指令来定义;4、变量:与高级语言一样,并不是所有的操作数都是常数,汇编语言也有自己的变量,变量的值在程序运行期间是可以被改变的;A.定义变量:汇编语言中,变量的定义是通过伪指令来完成的;定义变量的伪指令格式如下:变量名 DB 表达式 ;定义字节变量,又称单字节变量(1个连续字节),DB--》BYTE变量名 DW 表达式 ;定义字变量,又称双字节变量(2个连续字节),DW--》WORD变量名 DD 表达式 ;定义双字变量,又称四字节变量(4个连续字节),DD--》DWORD变量名 DF 表达式 ;定义六字节变量,又称六字节变量(6个连续字节),DF--》FWORD变量名 DQ 表达式 ;定义长字变量,又称八字节变量(8个连续字节),DQ--》QWORD变量名 DT 表达式 ;定义十字节变量(10个连续字节),DT--》TBYTE;其中,变量名是一个合法的标识符,变量名后面不能加冒号“:“,只能用空格;变量名不是必要的,可有可无;变量的类型由关键字DB、DW、DD、DQ、DT来定义;变量定义语句中的“表达式“是用于对变量进行初始化的,可有一下几种情况:(1).一个或多个常数或表达式;当为多个常数或表达式时,期间要用逗号隔开;如DATA1--DATA4;(2).带单引号的字符串;对于字节型(DB)变量,每个变量的大小为1个字节,每个变量的值不能超过1个字符,每个字节内存入一个字符的ASCII码值,整个字符串可以在同一对单引号内给出,这相当于是定义了一个字符数组,如DATA5;对于字类型(DW)变量,每个变量的大小为2个字节,每个变量的值不能超过2个字符,若为2个字符时,同样遵循高位存入高字节,低位存入低字节的规则;若为1个字符,则该字符的ASCII码值存入到低字节,高字节为00,如DATA6;对于双字类型(DD)变量,每个变量的大小为4个字节,每个变量的值不能超过2个字符,若为2个字符,同样遵循高位存入高字节,低位存入低字节的规则;但是2个字符的值被存入到双字变量的最低2个字节中,1个字符的值被存入到双字变量的最低1个字节中;对于长字类型(DQ)变量,每个变量的大小为8个字节,每个变量的值不能超过2个字符,若为2个字符,同样遵循高位存入高字节,低位存入低字节的规则;但是2个字符的值被存入到长字变量的最低2个字节中,1个字符的值被存入到长字变量的最低1个字节中;(3).一个问号“?“,表示该变量的值不确定,即:该变量所表示的内存单元中的内容是不确定的,或者说是,当表达式为问号时,变量所对应的内存区中并没有存入新的值,而只是预留出了相应的存储空间;如DATA7、DATA8(4).重复方式;此时的格式为: 重复次数 DUP(表达式);重复方式指出表达式的值可以重复地存储到变量对应的内存区中,重复的次数由伪指令给出,相当于定义数组;如DATA9、DATA10定义变量的例子:DATA1 DB 20H ;1字节变量DATA2 DW 0204H,1000H ;2字节变量DATA3 DB (-1*3),(15/3) ;1字节变量DATA4 DD 123456H ;4字节变量DATA5 DB ’0123’ ;字符串变量,相当于一个字符数组DATA6 DW ’AB’,’C’,’D’ ;字符串变量,相当于一个字符串数组;DATA7 DB ? ;1字节变量,未初始化DATA8 DD ? ;4字节变量,未初始化DATA9 DB 5 DUP(0) ;1字节变量,用5个0初始化,相当于是一个具有5个DB型元素的数组DATA10 DW 3 DUP(?) ;2字节变量,未初始化,相当于是一个具有3个DW型元素的数组变量定义语句中伪指令的功能是在变量名所对应的地址开始的内存区依次存入表达式中的各项值,表达式中的每项值所占用内存字节数与变量的类型对应;总结:一个变量的变量名实际上就代表了该变量所对应的内存区在内存段中的有效地址(偏移地址);高地址是指地址值相对较大,低地址是指地址值相对较小,高地址与低地址是相对而言的;5、变量的属性:(1).属性介绍一个变量具有一下属性:A.段地址(SEG):变量所在段的段地址;B.偏移地址(OFFSET):变量所在段内的偏移地址;C.类型(TYPE):变量的类型定义了每个变量所占用的内存字节数,对于DB、DW、DD、DQ、DT类型定义的变量所占用的内存字节数分别是1、2、4、8、10;通常又将DB、DW、DD类型所定义的变量分别成为BYTE类型、WORD类型、DWORD类型变量;常用标识符的类型值列表:标识符种类 字节变量 字变量 双字变量 近标号NEAR 远标号FARTYPE的值 1 2 4 -1 -2D.长度(LENGTH):变量定义时,一个变量名所定义的变量个数;在含有DUP操作符的变量定义中,变量名所定义的变量个数为定义格式中的重复次数;在其它各种变量定义中,每个变量名所定义的变量个数均为1个;E.大小(SIZE):变量定义语句中,分配给同一个变量名的所有变量的总的字节数,其值为该变量的类型与长度的成绩;其中,段地址、偏移地址和类型属性是变量的主属性,而长度和大小属性是变量的辅助属性;(2).属性操作符:操作符 表达式 含义SEG SEG 变量名或标号 取出变量名或标号所在段的段地址OFFSET OFFSET 变量名或标号 取出变量名或标号所在段内的偏移地址TYPE TYPE 变量名或标号 取出变量名或标号的类型(变量所占用的字节数)LENGTH LENGTH 变量名 取出变量的长度SIZE SIZE 变量名 取出变量的大小这些操作符不能单独构成语句,只能作为表达式的组成部分,并且表达式的求值也是在汇编过程中完成的;6.强制类型转换操作符PTR格式:数据类型 PTR 地址表达式格式中的“数据类型“可以是BYTE、WORD、DWORD、NEAR、FAR;前三种类型是变量的类型,后两种类型是标号的类型;格式中的表达式可以是变量、标号、其它地址表达式;PTR操作符的功能是用来重新定义已定义的变量或标号的类型,其作用域只在当前语句中; 例如:DATA1 DW 02HMOV BYTE PTR DATA1,AL这条指令中,是把DATA1的类型转换为BYTE类型,然后把AL中的内容存放到DATA1的最低一个字节中;作用域只在这条MOV语句中,过了这条语句,DATA1仍然是DW类型,即:DATA1原来的类型并没有被修改;

怎么用C语言求二分法

二分法查找有一个前提,数据应该是排好序的,假设从小到大排列,则:首先用中间那个数(也可以不是正中间,差一两位没有关系,只要保证不忽略数据就行)与查找值比较,大于查找值就跳到左边。然后重新设定新的数列。新的数列为,从最小的数值到中间那个数。以这个新的数列为基础,重复以上步骤。

汇编语言指令有哪些

一、数据位传送指令:

1、MOV   C,  bit     ;bit  可直接寻址位 C←(bit)

2、MOV   bit,C     ;C    进位位 (bit) ← C 二、位变量修改指令:

1、CLR    C          ; 将C=0

2、CLR    bit

3、CPL    C           ; 将C求反再存入C

4、CPL    bit          ; 将bit求反再存入bit

5、SETB   C          ; 将C=1

6、SETB   bit          ; (bit) ← 1 三、位变量逻辑指令:

ANL   C,   bit    ANL   C,   bit    ORL   C,   bit   ORL   C,   bit

延展阅读:

汇编指令是汇编语言中使用的一些操作符和助记符,还包括一些伪指令(如assume,end)。用于告诉汇编程序如何进行汇编的指令,它既不控制机器的操作也不被汇编成机器代码,只能为汇编程序所识别并指导汇编如何进行。

通用数据传送指令:

1、MOV 传送字或字节;

2、MOVSX 先符号扩展,再传送;

3、MOVZX 先零扩展,再传送;

4、PUSH 把字压入堆栈;

5、POP 把字弹出堆栈;

6、PUSHA 把AX,CX,DX,BX,SP,BP,SI,DI依次压入堆栈;

7、POPA 把DI,SI,BP,SP,BX,DX,CX,AX依次弹出堆栈;

8、PUSHAD 把EAX,ECX,EDX,EBX,ESP,EBP,ESI,EDI依次压入堆栈;

9、POPAD 把EDI,ESI,EBP,ESP,EBX,EDX,ECX,EAX依次弹出堆栈;

10、BSWAP 交换32位寄存器里字节的顺序;

11、XCHG 交换字或字节( 至少有一个操作数为寄存器,段寄存器不可作为操作数);

12、CMPXCHG 比较并交换操作数( 第二个操作数必须为累加器AL/AX/EAX );

13、XADD 先交换再累加( 结果在第一个操作数里 );

14、XLAT 字节查表转换;

15、BX 指向一张 256 字节的表的起点, AL 为表的索引值 (0-255,即0-FFH);

16、返回 AL 为查表结果。( [BX+AL]-》AL )


声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,谢谢。

上一篇: 冬泳网红美女抖音号(冬泳网)

下一篇: spring boot(springboot启动流程是什么)



推荐阅读

网站内容来自网络,如有侵权请联系我们,立即删除! | 软文发布 | 粤ICP备2021106084号