打算整理汇编语言与接口微机这方面的学习记录。本部分介绍汇编语言程序设计以及一些跟程序设计密切相关的指令类。
参考资料
段定义伪指令
程序不同的信息要定义在不同的段中,该指令就
SEGNAME SEGMENT [定位类型][组合类型]['类别']
;段实体
SEGNAME ENDS
定位类型是告诉汇编器这个逻辑段起始地址的要求,取值有:

常用是PARA 节型。
组合类型是多模块程序设计中告诉链接器器,不同模块中同段名同组合类型的逻辑段如何链接。
课程只要求单模块编程,所以组合类型不了解也罢。
老师这里提了STACK型(说明本段是堆栈段),例子:
STACK SEGMENT STACK
DB 256 DUP(?)
STACK ENDS
注意这里第一行的第二个STACK声明为组合类型后,就不需要在代码段设置SS和SP了,如果不写这个组合类型声明,代码段还是需要声明。
另一个组合类型是NONE类型,缺省型。其他的暂且不提。
类别,如果要写,需要加上单引号说明,只告诉程序员这个段是干什么的,类似于段前注释,没有其他用处。
;定义堆栈
STACK SEGMENT STACK
DB 256 DUP(?)
;定义堆栈段,找16可以整除的,SP = 栈底+1
TOP LABEL WORD
;TOP为变量名;TOP 不占用内存位置,获取SP的地址;LABEL伪指令只有存储单元地址、类型属性但是不占内存位置
STACK ENDS
;定义数据段(可能有多个)
DATA SEGMENT
;实体
DATA ENDS
X_BYTE LABLE BYTE;这样就可以直接使用34H这个字节型变量X_BYTE,而不用对X_WORD进行类型转换。
X_WORD DW 1234H
;定义代码段
CODE SEGMENT
ASSUME CS:CODE,DS:DATA,ES:DATA;段寻址伪指令,告诉汇编程序段名和段的关系
ASSUME SS:STACK
;这种关系是承诺关系,并没有向这些寄存器赋值,还需要再赋值
START:MOV AX,DATA
MOV DS,AX;数据初始化,不能直接DATA给DS
MOV ES,AX
/* MOV AX,STACK
MOV SS,AX
MOV SP,OFFSET TOP*/
;相当于STACK组合类型的作用
/* MOV AH,4CH
INT 21H */
;DOS系统的4CH对应的中断子程序,此处是结束用户程序返回操作系统
CODE ENDS;代码段结束
END START(CS:IP);整个程序结束
;初始化CS,ip,放置这段代码。其实是交给OS来做了,用户无权。
上面的完整程序结构中已经提了很多伪指令,简单提一提其他伪指令。
EQU 和 = 伪指令
VAR_NAME EQU/= Exp;给表达式赋一个名称
;用EQU定义时,这个VAR_NAME只能EQU定义一次,用=定义则可以再次定义
ORG伪指令
ORG 表达式
为后续指令指定段内偏移地址,可以人为使字型数据对齐。
举个例子:操作系统中的boot.asm中对于 org07c00h是这样注释的:“告诉编译器程序加载到7c00h处”:
org 07c00h
;告诉编译器程序加载到7c00h处
mov ax,cs
mov ds,ax
mov es,ax
call screen
jmp $
screen:mov ax,bootmsg
mov bp,ax
mov cx,16
mov ax,01301h
mov bx,000ch
mov dl,0
int 10h
ret
bootmsg:db'Hello OS world!'
times 510-($-$$) db 0
dw 0xaa55
想直接听后面的了,不想听前面的指令系统了,折磨。
这部分是3.11和4.5合在一起讲,前者是子程序调用返回指令,后者是子程序程序设计。
子程序/过程就是汇编语言里的函数,将一些功能性、重复性的代码放到子程序中调用,可以让自己的代码更加清晰。我们需要在主干代码调用子程序,在子程序结束时返回。
子程序定义:
以过程形式定义:
son_name1 PROC [类型]
;主体
RET;子程序返回,段间子程序可以用RETF
son_name1 ENDP
上面代码中的[类型]:
以标号形式定义(比较方便):
LABEL:
;主体
RET
子程序调用与返回
段内子程序调用与返回
CODE SEGMENT
ASSUME CS:CODE
START:
……
CALL SUB1;段内直接寻址
; call near sub1的near可以缺省
; ……CS不发生改变
MOV AH,4CH
INT 21H
SUB1 PROC
RET
SUB1 ENDP
CODE ENDS
END START
段间子程序调用与返回
CODE1 SEGMENT
ASSUME CS:CODE1
START:
……
CALL FAR PTR SUB1;段内直接寻址
;……CS:IP(CS和IP都要保存)
MOV AH,4CH
INT 21H
CODE1 ENDS
CODE2 SEGMENT
ASSUME CS:CODE2
SUB1 PROC FAR
……
RETF;也可以直接写为RET
SUB1 ENDP; 子程序/过程结束指令
CODE2 ENDS
也就是主程序和子程序会复用一些寄存器和存储器单元,调用子程序时需要保存主程序的这些东西,这个过程在主程序或子程序中都可以进行,通常在子程序中进行。
寄存器、存储器、堆栈都能传递参数。
至于怎么传递,其实就是一个程序设计者自己规定的过程,比如主程序将参数放到AX,子程序从AX来拿。在堆栈参数传递参数方式时,需要用到BP指针。
作为学生,这部分当然不写,了解一下吧。
这一节偏实践,纸上论道不可取。用到再说吧,个人汇编编程经验感觉子程序这部分不难,这是要保护信息恢复信息。可再入不大明白(那就尽量不设计)。
这里有几个子程序设计例程,我感觉还不错。例3.32、例3.33、例3.34。
3.12,结合了一部分第8章中断系统的知识。
说实话,"中断" 这个词通过操作系统OS这个课已经比较了解了,这里从微机角度温习一下。
但感觉这部分讲的有点乱。
中断:是CPU执行程序时,由于某个事件的发生,暂停当前正在执行的程序,去执行处理这个事件的中断服务程序,执行完毕后再返回原程序继续执行。
中断分为外部可屏蔽中断、外部不可屏蔽、内部中断(软件中断)。具体如下图:

为了识别中断形式并采取对应服务,CPU都编排了中断类型号,这个具体CPU要查手册。
8086中:
除法错:n=0
单步中断:n=1
断点中断:n=3
int 3指令可以临时替换原有的指令,叫做设置断点,程序执行到int 3时,会进入类型3的中断服务程序,可以在中断服务程序中读原执行环节,来观察哪里有问题,之后再返回原程序,继续执行。
int n
更泛指,比如DOS系统功能调用
INT 21H
后续会学上图中的中断处理硬件,8259A。
中断向量其实是中断服务程序的指针,存放中断服务程序的入口地址。

系统将中断向量组织成中断向量表(换算表),放置在存储器最低地址0000H开始的1024个单元。每个中断向量占4B:
入口地址的偏移地址在低2字节,段基址在高2字节。所以调用时也是对应交给IP和CS。
换算关系是:中断类型号*4就是该中断向量在中断向量表中的开始地址。
中断向量表在OS初始化时就设置了。在自己写操作系统时,可以设置这个表。
中断调用指令: INT n
CPU执行以下操作:
保护现场:PSW IP CS 入栈
清除 IF TF 标志(TF清0说明中断期间CPU不会再中断)
从中断向量表中取出中断向量给CS IP赋值。
如果是外部硬件中断,不知道这个查表要用的n,CPU需要从外部硬件中获取中断类型号。
转到中断服务程序执行。
中断服务最后一句,中断返回:IRET,将IP CS PSW出栈。返回原程序。
再来说说外部中断的中断号获取:

简单先说一下上图的情况,是在说8086的中断引脚情况
NMI不可屏蔽中断就不提了。
INTR引脚:
只有一个8259则只能控制8个硬件,可以采用8259级联的方式来增加控制硬件数。
这里可以算控制硬件个数,但是不难。
中断很像子程序,但是有所不同,因为中断随时可能发生,自己写的主程序无法预料何时发生中断,所以中断程序内部开始时应当有保护现场操作,返回时有恢复现场操作。
INT_NAME:
PUSH AX ;保护现场操作
;......
PUSH SI
; 主体
; ...
POP SI ;恢复现场操作
POP AX
IRET ;中断返回
系统调用分为两类
DOS系统功能调用的方法一般可分为以下几步:
INT 21H指令自动转入中断子程序入口。常用的DOS功能调用有 INT 21H,AH里放参数决定具体服务(如果需要参数),比如放入01H就是等待用户从键盘输入一个字符,回显,按键的ASIIC码放到AL中。
补充一个小知识:
ASCII数字如何得到数字:
AND AL,0FH;消除高位即可
这里举了一个键盘按键并回显的例程,跳转表法,挺巧妙的,老师讲了两个跳转表法的实现方式,第一个是在课本4.25,第二个就是将跳转表定义到了代码段。
其他的不再写了,主要就是设置参数,设置调用号再辅以子程序实现相应的功能:
- 02H向屏幕输出一个字符
- 06H 控制台输入、输出
- 09H 向屏幕输出一串字符(字符串数据变量定义时必须要有结束符 '$')
DOS与BIOS 系统调用一览:https://blog.csdn.net/icurious/article/details/51628343
0AH 从键盘输入一串字符(有等待功能,键盘输入回车时结束输入并显示),此时必须有键盘缓冲区(存储器中):
DATA SEGMENT
……
KEYbuf1 DB 20H;允许用户输入的字符个数
DB ?;用来统计实际输入的字符数
KEYbuf2 DB 20H DUP(?);存放实际输入的字符串
;键盘输入缓存区
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DATA
START:
MOV AX,DATA
MOV DS,AX
……
;从键盘输入一串字符,有回显
MOV AH,0AH
MOV DX,OFFSET KEYbuf1
INT 21H
......
课后题4.39题回头看看。
显示系统时间:(这里是DOS系统调用获取,当然也可以用cmos获取--王爽汇编实验14,不过还没有讲到与外设交互)
;返回值:CX = year (1980-2099) DH = month DL = day AL = day of week (00h=Sunday)
data segment
data ends
code segment
assume ds:data, cs:code
main:
mov ax, data
mov ds, ax
mov ah, 2ah
int 21h
mov ah, 4ch
int 21h
code ends
end main
00H 设置显示器,清屏功能
MOV AH,00H
MOV AL,3;彩色文本,且大小是80X25
MOV BX,0;页数,与显卡数据缓存区有关
INT 10H
02H 设置光标位置
MOV AH,02H
MOV DH,行
MOV DL,列
MOV BL,0
INT 10H
对传送指令再升级,对一组数据进行整体操作。
源字符串和目的字符串均为隐含寻址
如果源串在存储器中,则存储器的的地址在DS:SI;
若源串在REG中,字节:AL,字:AX
目的字符串,必须在ES:DI(必须对应)
在REG同上
如果源串目的串在存储器中,则CPU执行时,SI、DI的地址会自动改变,这个改变受DF的控制:
DF=0时, +;
DF=1时, -;
这里在编程时需要向其赋值确保其值。如确保DF==0:
CLD
± 的程度受操作数类型大小的控制(放在头部或尾部):若为字节操作自动+1/-1,若为字操作自动+2/-2
在串操作指令的左边可以增加重复前缀,重复次数隐含放在CX中
串传送指令
MOVSB
MOVSW
串比较指令
CMPSB
CMPSW
源字符串减去目的字符串(对应位置依次比较),设置状态寄存器
串扫描指令
SCASB
SCASW
串装入指令
LOOSB
LOOSW
串存贮指令
STOSB
STOSW
三种书写格式:MOVSB、MOVSW,MOVS DST,SRC。
以MOVSB存储器操作为例:
ES:DI<-- DS:SI
源串段地址可以更改(如使用第三种书写格式),而目的串寄存器不可更改,见书P74页ES段到ES段的传送。
SI和DI会自动+/-
若加上REP重复前缀,则执行第三步,CX-1->CX,若CX≠0,则重复执行MOVSB
例题见P75 例3.36
DATA SEGMENT
BUFFER1 DB 100 DUP(?)
BUFFER2 DB 100 DUP(?)
DATA ENS
CODE SEGMENT
ASSUME CS:CODE,DS:DATA,ES:DATA
START:
MOV AX,DATA
MOV DS,AX
MOV ES,AX
LEA SI,BUFFER1
MOV DI,OFFSET BUFFER2
CMP SI,DI
//JB DZJXFX
MOV CX,100
/*CLD ;DF=0
REP MOVSB 字符串指令*/
;下面是数据指令完成的
N1: MOV AL.[SI]
MOV ES:[DI],AL
INC SI
INC DI
LOOP N1
MOV AH,4CH
INT 21H
CODE ENDS
END STRAT
若源串和目的串重叠,视情况正向搬运或者逆向搬运。(有两种情况:
CMPSB CMPSW CMPS DST,SRC
以CMPSW为例:(源减去目的,这与数据比较指令不同)
SRC-DST,也即是(DS:SI)-(ES:DI),设置6个状态寄存器,若ZF==1,说明相等。
SI DI 自动+/- 2
若有重复前缀REPZ,(CX-1)-->CX,若CX≠0且ZF=1,重复执行CMPSW
若前缀REPNZ,则修改上面条件改为ZF=0即可:若CX≠0且ZF=0
例程在书P76 例3.37
MOV SI,OFFSET BUFFER1
MOV DI,OFFSET BUFFER2
MOV CX,100
CLD
REPNZ CMPSW
JZ Find
MOV ADDR,0FFFFH
JMP EXIT
Find:SUB SI,2
MOV ADDR,SI
……
MOV AH,4CH
INT 21H
SCASB、SCASW、SCAS DST,适用于在字符串中找某个字符或筛出某个字符。
以SCASB为例:
LODSB LODSW,意为将源字符串(存储器中)读出到AL/AX中。
以LODSB为例:
这里老师讲了两个计算机通信的例子,8250,emm,略去。
STOSB STOSW STOS
以STOSB为例:
例程P79 例3.39
DATA SEGMENT
BUFFER1 DW
BUFFER2 DB
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DATA,ES:DATA
STRAT:
LEA DI,BUFFER1
MOV AX,0000H
MOV CX,200
CLD
REP STOSW
/*也可以改为
L1:MOV ES:[DI],AX
INC DI
INC DI;字,所以减了两次
LOOP L1
*/
LEA DI,BUFFER2
MOV AL,55H
MOV CX,256
CLD
REP STOSB
例子2,P112例4.7
输入输出指令针对I/O操作。
格式:IN DST, SRC,这里SRC是端口地址(8086的前16根地址线寻址),
若端口地址在0~255之间,SRC可以采用直接寻址:
IN AL,端口地址
若端口地址>255,需采用间接寻址(都可以采用间接寻址)。
MOV DX,端口地址
IN AL,DX;触发IO操作的地址寄存器
;符合语法,虽然DX没加括号,但是合法
;这里的意思比较抽象,就是地址放在DX中,in进来的内容放在AL中
上述所说是字节操作,若为字操作,则AL改为AX。
格式:OUT DST, SRC,操作数交换一下,其他要求与输入完全一致。

这里老师举了一个外设操作例子(P61最后~P62),讲得很好,很整体,甚至包括了IO地址译码电路(控制信号也要参与译码d),但学到外设再说。
这部分直接看书更快。
标志位处理指令,详见笔记3的标志位处理指令(7个)
处理器控制指令 5个
空操作指令 NOP,什么也不做,占用机器3个时钟周期,用于延时、等待。
看一个延时子程序(双层循环):
MOV BX,3;一个值,外层循环的次数
L2: MOV CX,0;65536
L1: NOP
LOOP
DEC BX
JNZ L2
暂停指令 HLT,使CPU进入暂停状态,不再向下执行。退出条件:
RESET信号有效直接复位,或者NMI不可屏蔽中断。此时退出但也不会执行后续程序。
INTR可屏蔽中断发生,CPU保护当前程序现场(IP指针在hlt的下一句),保护了当前程序,返回后则继续执行后续程序。
这个可以用于CPU跟外设的同步(用的不多)
WAIT等待指令,每隔5个时钟周期对TEST引脚状态进行测试,当TEST线低电平则退出等待,执行下一条指令。
宏定义指令定义出来的自定义指令。宏指令必须在程序最开头定义。
宏指令名 MACRO <形式参数>;参数多于1项,用逗号分隔
; ... ;指令或伪指令构成的宏体
ENDM ;宏定义指令结束,注意这里结束不需要写宏名
例子:
;定义一条宏指令,将<某通用寄存器REG><左/右移><若干次>
SHIFT MACRO REG,DIR,N
MOV CL,N
DIR REG,CL;或者:S&DIR REG,Cl
; 因为 SHL,SHR,SAL,SAR 都以S开头
ENDM
;某程序体中,将AX逻辑左移3次:宏调用如下:
SHIFT AX,HL,3
当汇编器汇编到这个宏调用时,会将前面的宏定义的形参替换掉,并插入此处(宏展开)。
宏调用和子程序都可以来放一个经常调用的功能模块,但区别在于:
;定义一条宏指令,完成光标回车换行
CRLF MACRO
MOV AH,2
MOV DL,0DH
INT 21H
MOV AH,2
MOV DL,0AH
INT 21H
ENDM
一个值得研讨的点:当宏指令中有循环或分支,也就是有标号,主程序多次宏调用时,会提示标号重复:
此时应当将标号声明为 局部标号: LOCAL NEXT,汇编时自动分配不同标号。
;数据块搬家
DATAMOV MACRO DATA1,DATA2,N
LOCAL NEXT;声明NEXT是局部标号
LEA SI,DATA1
LEA DI,DATA2
MOV CX,N
NEXT: MOV AL,[SI]
MOV [DI],AL
INC SI
INC DI
LOOP NEXT
ENDM
; ……
; 主程序中的宏调用
DATAMOV buf1,buf2,100
;汇编展开;
; LOOP NEXT变为LOOP ??0000
; ......
DATAMOV buf3,buf4,200
;汇编展开
;LOOP NEXT变为LOOP ??0001
除了上面介绍的,还有重复宏,格式是:
; 重复宏 REPT <重复次数>: ;重复程序体 ENDM ; 也是以此结尾 ; 不定重复宏 IRP <形参>, < <参数1>,<参数2>,...> ;重复程序体 ENDM ; 也是以此结尾 ;不定字符重复宏 IRPC <形参>,<字符串>;将字符串中的各个字符依次赋给形参重复执行指定程序体 ;重复程序体 ENDM ; 也是以此结尾 IRPC CC,AAB ADD AX,CC&X ENDM /* 相当于 ADD AX,AX ADD AX,AX ADD AX,BX */
单分支程序;多分支程序
要点1是分支条件:
多分支程序结构与上面几步类似,此外还可以通过跳转表来实现多分支
要点2是转移范围:
要点3是程序调试时要保证每个分支结果的正确性(因为单次调试可能只走了其中一条分支)
要点4:分支程序设计要点
例子:书P112例4.7,两递增数组合并。
STACK SEGMENT STACK 'STACK'
DW 100H UP(?)
TOP LABLE WORD
STACK ENDS
DATA SEGMENT
DAT1 DW 10
DB 10H,25H,67H,73H,83H,95H,0A8H,0C2H,0E6H
DAT2 DW 13
DB 05,12H,45H,58H,65H,67H,70H,76H,88H,92H,0CDH,0DEH
DAT DW ?
DB 200 DUP(?)
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DATA,ES:DATA,SS:STACK
START:
; 一些初始化
MOV AX, DATA
MOV DS, AX
MOV ES, AX
MOV AX, STACK
MOV SS, AX
LEA SP, TOP
; 计算 目标数组 大小
MOV CX, DAT1
MOV DX, DAT2
MOV DAT, CX
ADD DAT, DX
; 置位三个指针,ES:SI,DS:BX,ES:DI
LEA SI, DAT1+2
LEA BX, DAT2+2
LEA DI, DAT+2
CLD
L1:
MOV AL, [BX]
INC BX
L2:
CMP AL,[SI]
JB L3; AL<[SI],去L3
; AL>=[SI],向下执行
MOVSB
DEC CX ;控制循环次数,DAT1数组是否比较完成
JZ L4 ;结束
JMP L2 ;无条件循环L2
L3:
STOSB ;DAT2区数据传送到DAT
DEC DX
JZ L5 ;如果两边数组有剩余
JMP L1
L4:
MOV SI,BX
DEC SI
MOV CX,DX
L5:
REP MOVSB
MOV AH,4CH
INT 21H
CODE ENDS
END START
循环程序组成
例程,气泡排序法程序:书P108页例4.5
核心代码:
; 初始化部分
MOV CH,N-1;外层
NEXT2:
MOV CL,CH; 内层
LEA SI,BUF1; 数组首址
MOV BL,0; 交换标志
; 循环工作
NEXT1:
MOV AL,[SI]
CMP AL,[SI+1]
JAE NOCHG ;AL>=[SI+1]不交换
;否则交换
XCHG AL,[SI+1]
MOV [SI],AL
MOV BL,-1 ;有交换,说明未排完
NOCHG:
; 调整循环条件并判定出口
INC SI;
DEC CL
JNZ NEXT1 ;未到0继续内层交换
;否则继续外层循环
CMP BL,0;是否已经排好序
JZ EXIT ;如果排好序则退出
DEC CH
JNZ NEXT2
EXIT: MOV AH,4CH
INT 21H
警惕程序挖空填写题。
我有一个模型:classItem项目有一个属性“商店”基于存储的值,我希望Item对象对特定方法具有不同的行为。Rails中是否有针对此的通用设计模式?如果方法中没有大的if-else语句,这是如何干净利落地完成的? 最佳答案 通常通过Single-TableInheritance. 关于ruby-on-rails-Rails-子类化模型的设计模式是什么?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.co
我将应用程序升级到Rails4,一切正常。我可以登录并转到我的编辑页面。也更新了观点。使用标准View时,用户会更新。但是当我添加例如字段:name时,它不会在表单中更新。使用devise3.1.1和gem'protected_attributes'我需要在设备或数据库上运行某种更新命令吗?我也搜索过这个地方,找到了许多不同的解决方案,但没有一个会更新我的用户字段。我没有添加任何自定义字段。 最佳答案 如果您想允许额外的参数,您可以在ApplicationController中使用beforefilter,因为Rails4将参数
电脑0x0000001A蓝屏错误怎么U盘重装系统教学分享。有用户电脑开机之后遇到了系统蓝屏的情况。系统蓝屏问题很多时候都是系统bug,只有通过重装系统来进行解决。那么蓝屏问题如何通过U盘重装新系统来解决呢?来看看以下的详细操作方法教学吧。 准备工作: 1、U盘一个(尽量使用8G以上的U盘)。 2、一台正常联网可使用的电脑。 3、ghost或ISO系统镜像文件(Win10系统下载_Win10专业版_windows10正式版下载-系统之家)。 4、在本页面下载U盘启动盘制作工具:系统之家U盘启动工具。 U盘启动盘制作步骤: 注意:制作期间,U盘会被格式化,因此U盘中的重要文件请注
在应用开发中,有时候我们需要获取系统的设备信息,用于数据上报和行为分析。那在鸿蒙系统中,我们应该怎么去获取设备的系统信息呢,比如说获取手机的系统版本号、手机的制造商、手机型号等数据。1、获取方式这里分为两种情况,一种是设备信息的获取,一种是系统信息的获取。1.1、获取设备信息获取设备信息,鸿蒙的SDK包为我们提供了DeviceInfo类,通过该类的一些静态方法,可以获取设备信息,DeviceInfo类的包路径为:ohos.system.DeviceInfo.具体的方法如下:ModifierandTypeMethodDescriptionstatic StringgetAbiList()Obt
嗨~大家好,这里是可莉!今天给大家带来的是7个C语言的经典基础代码~那一起往下看下去把【程序一】打印100到200之间的素数#includeintmain(){ inti; for(i=100;i 【程序二】输出乘法口诀表#includeintmain(){inti;for(i=1;i 【程序三】判断1000年---2000年之间的闰年#includeintmain(){intyear;for(year=1000;year 【程序四】给定两个整形变量的值,将两个值的内容进行交换。这里提供两种方法来进行交换,第一种为创建临时变量来进行交换,第二种是不创建临时变量而直接进行交换。1.创建临时变量来
目录前言滤波电路科普主要分类实际情况单位的概念常用评价参数函数型滤波器简单分析滤波电路构成低通滤波器RC低通滤波器RL低通滤波器高通滤波器RC高通滤波器RL高通滤波器部分摘自《LC滤波器设计与制作》,侵权删。前言最近需要学习放大电路和滤波电路,但是由于只在之前做音乐频谱分析仪的时候简单了解过一点点运放,所以也是相当从零开始学习了。滤波电路科普主要分类滤波器:主要是从不同频率的成分中提取出特定频率的信号。有源滤波器:由RC元件与运算放大器组成的滤波器。可滤除某一次或多次谐波,最普通易于采用的无源滤波器结构是将电感与电容串联,可对主要次谐波(3、5、7)构成低阻抗旁路。无源滤波器:无源滤波器,又称
项目介绍随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱小学生兴趣延时班预约小程序的设计与开发被用户普遍使用,为方便用户能够可以随时进行小学生兴趣延时班预约小程序的设计与开发的数据信息管理,特开发了小程序的设计与开发的管理系统。小学生兴趣延时班预约小程序的设计与开发的开发利用现有的成熟技术参考,以源代码为模板,分析功能调整与小学生兴趣延时班预约小程序的设计与开发的实际需求相结合,讨论了小学生兴趣延时班预约小程序的设计与开发的使用。开发环境开发说明:前端使用微信微信小程序开发工具:后端使用ssm:VU
需求:要创建虚拟机,就需要给他提供一个虚拟的磁盘,我们就在/opt目录下创建一个10G大小的raw格式的虚拟磁盘CentOS-7-x86_64.raw命令格式:qemu-imgcreate-f磁盘格式磁盘名称磁盘大小qemu-imgcreate-f磁盘格式-o?1.创建磁盘qemu-imgcreate-fraw/opt/CentOS-7-x86_64.raw10G执行效果#ls/opt/CentOS-7-x86_64.raw2.安装虚拟机使用virt-install命令,基于我们提供的系统镜像和虚拟磁盘来创建一个虚拟机,另外在创建虚拟机之前,提前打开vnc客户端,在创建虚拟机的时候,通过vnc
我在我的项目中有一个用户和一个管理员角色。我使用Devise创建了身份验证。在我的管理员角色中,我没有任何确认。在我的用户模型中,我有以下内容:devise:database_authenticatable,:confirmable,:recoverable,:rememberable,:trackable,:validatable,:timeoutable,:registerable#Setupaccessible(orprotected)attributesforyourmodelattr_accessible:email,:username,:prename,:surname,:
因为我现在正在做一些时间测量,我想知道是否可以在不使用Benchmark类或命令行实用程序time的情况下测量用户时间或系统时间。使用Time类只显示挂钟时间,而不显示系统和用户时间,但是我正在寻找具有相同灵active的解决方案,例如time=TimeUtility.now#somecodeuser,system,real=TimeUtility.now-time原因是我有点不喜欢Benchmark,因为它不能只返回数字(编辑:我错了-它可以。请参阅下面的答案。)。当然,我可以解析输出,但感觉不对。*NIX系统的time实用程序也应该可以解决我的问题,但我想知道是否已经在Ruby中实