Hack Programming
计算机由ROM(instruction memory)、RAM(data memory)、CPU组成,其关系如下图

在计算中存在3种寄存器:D、A、M。其中D是data register,A是address register,M是data/address register。
为对数据进行操作,存在两种指令:A-introduction,C-introduction,这也就是Hack Promramming的全部语法了。Hack Programming 属于一种 汇编语言(Assembly language),计算机处理的都是0/1,但不便于阅读编程,但汇编语言通过编译可以成为二进制语句。
A-introduction的语法就是 @ num,num可以是非负整数,也可以variable/LABEL,这个语句可以应用于三种情况:
1)赋值A。A是地址,比如@2,就是令当前的A=2,并可以对M = RAM[A]进行操作
2)指定寄存器RAM[A]。
3)指定下一条指令。这里的指定下一条指令一般是用于 @LABEL,实现goto功能,这一语句经过编译会变为 @ num,num是定义LABEL的下一行的行数。举例如下

注:关于variable:和LABEL不同,不需要在程序中申明,编译时会自动寻找可行的寄存器,比如@i,编译时会变为 @num,num表示寄存器的地址。
C-Instruction的语法如下,主要功能是实现运算和赋值。

此外,还有一个POINTER的概念,其实就是地址,在HACK编程的C指令中,只能用上面涉及到的语法,所以要实现赋值操作一般都是下面这样
// i = 100 @ D = A @i M = D //修改SCREEN MAP第2个寄存器的值全为1 @SCREEN D = A A = A+ M = -
最后还有屏幕输出和键盘输入。
假设屏幕大小是256*512,计算机是16bit,那32个寄存器对应屏幕的一行,依次下推,这样用于屏幕输出的寄存器就需要256*512/16个;屏幕的每一个pixel都只有0/1,1的话就是黑色,要改变屏幕输出,其实通过要改变的像素点,找到相应寄存器的相应bit,再改变bit的值为1。
键盘输入只需要一个寄存器,一般会有个固定地址,当进行键盘输入时,其寄存器的值M就不为0,而是输入字符的对应码。
举个栗子:实现当进行键盘输入时,屏幕的头16个像素变黑,松开时变白
@
D = A
@n
M = D
@SCREEN
D = A
@pointer
M = D
@isfill
M =
(LOOP)
@KBD
D = M;
@FILL
D;JNE
@UNFILL
D;JEQ
(FILL)
@isfill
D = M
@LOOP
D;JNE
@pointer
A = M
M = -
@isfill
M =
@LOOP
;JMP
(UNFILL)
@isfill
D = M
@LOOP
D;JEQ
@pointer
A = M
M =
@isfill
M =
@LOOP
;JMP
Hack Programming的更多相关文章
- Virtual Machine
之前说到可以使用Assembly language来实现程序编写,把程序通过一个Assembler就可以得到计算机可以操作的二进制文件. 但是Assembly language依旧不适于编程,但怎么将 ...
- net programming guid
Beej's Guide to Network Programming Using Internet Sockets Brian "Beej Jorgensen" Hallbeej ...
- 《Programming WPF》翻译 第7章 1.图形基础
原文:<Programming WPF>翻译 第7章 1.图形基础 WPF使得在你的应用程序中使用图形很容易,以及更容易开发你的显卡的能力.这有很多图形构架的方面来达到这个目标.其中最重要 ...
- URAL 1404. Easy to Hack! (模拟)
space=1&num=1404">1404. Easy to Hack! Time limit: 1.0 second Memory limit: 64 MB When Vi ...
- The Ultimate Productivity Hack is Saying No
The Ultimate Productivity Hack is Saying No By James ClearRead this on JamesClear.com The ultimate p ...
- Expert C Programming 阅读笔记(~CH1)
P4: 好梗!There is one other convention—sometimes we repeat a key point to emphasize it. In addition, w ...
- hack games
记下,有时间玩玩~ wargame http://www.wechall.net/lang_ranking/en --------------- Monyer系列(黑客游戏) 1. http://mo ...
- iOS Programming Camera 2
iOS Programming Camera 2 1.1 Creating BNRImageStore The image store will fetch and cache the image ...
- [PySpark] RDD programming on a large file
重难点 一.parallelize 方法 一般来说,Spark会尝试根据集群的状况,来自动设定slices的数目.然而,你也可以通过传递给parallelize的第二个参数来进行手动设置. data_ ...
随机推荐
- 程序员如何开始做一个自己的 Side Project?
此系列文章我们开始聊一些软件开发人员如何开始动手写一些自己项目(Side Project)的思路与方法,以及过程中可能需要准备的知识,并分享一些相关的资源给大家. 1. 什么是 Side Projec ...
- Nginx 关于进程数 与CPU核心数相等时,进程间切换的代价是最小的-- 绑定CPU核心
在阅读Nginx模块开发与架构模式一书时: "Nginx 上的进程数 与CPU核心数相等时(最好每个worker进程都绑定特定的CPU核心),进程间切换的代价是最小的;" &am ...
- xadmin后台页面的自定制(2)重写钩子函数版
由于项目有通过自定义页面来实现功能的需求,百度也查了很多资料,也没找到合适的方法,所以决定分析源码,通过对源码的分析,找到了此方法. 01-需求 首先,如果要在xadmin中展示一个数据管理页面,首先 ...
- gorose使用示例
package main import ( "fmt" "github.com/gohouse/gorose" //import Gorose _ " ...
- sqlalchemy常用
一.SQLAlchemy 创建表 from sqlalchemy.ext.declarative import declarative_base from sqlalchemy import Colu ...
- 控制结构(8): 线性化(linearization)
// 上一篇:管道(pipeline) // 下一篇:程序计数器(PC) "编程语言不过是一个工具,什么语言都一样","编程语言能改变人的思维,不同的语言会带给你不同的思 ...
- SyntaxError: missing ) after argument list
消息 语法错误: 参数列表后面缺少 ) 错误类型 SyntaxError. 什么地方出错了? 有一个函数在调用时出现错误.这可能是一个错误,丢失运算符或者转义字符等. 示例 因为没有使用 ”+“ 操作 ...
- EntityFramework Core笔记:表结构及数据基本操作(2)
1. 表结构操作 1.1 表名 Data Annotations: using System.ComponentModel.DataAnnotations.Schema; [Table("R ...
- mysql 的存储引擎介绍
在数据库中存的就是一张张有着千丝万缕关系的表,所以表设计的好坏,将直接影响着整个数据库.而在设计表的时候,我们都会关注一个问题,使用什么存储引擎.等一下,存储引擎?什么是存储引擎? 什么是存储引擎? ...
- 使用with语句优化pymysql的操作
一.with语句的好处 with语句的好处在于,它可以自动帮我们释放上下文,就比如文件句柄的操作,如果你不使用with语句操作,你要先open一个文件句柄,使用完毕后要close这个文件句柄,而使用w ...