Single threaded and asynchronous Javascript

Reference:

  1. A conclusion of Javascript running mechanism
  2. Detailed explanation of Javascript asynchronism
  3. JavaScript Event Loop And Call Stack Explained

Sinle-threaded Javascript

A running chrome consists of multiple process. Each tab is an isolated process.
chrom task manager
A tab process consisits of multiple threads. Among them the important ones includes:

  1. Rendering thread. Renders DOM.
  2. Javascript engine thread. Runs Javascript. Note that when Javascript engine thread runs, rendering thread hangs. Because Javascript engine thread can manipulate DOM and rendering requires a consistent DOM.
  3. Event thread. Handles event loop.
  4. Timer thread. Handles timer methods like setTimeout, setInterval. Timer thread should be stand-alone as running of other function may affect timing accuracy.

Asynchronism

Javascript, well-known for its asynchronism.
Synchronous functions runs and gets result. When function is slow (e.g. has file I/O or web request operations), it waits.
Asynchronous functions runs and expects result. The function does not wait for result, instead it leaves a callback function there to handle future result, and it moves on.
Asynchronism makes Javascript run without idle time. That’s why javascript is fast.

Event loop and call stack

Event loop and call stack
Browsers gives us Web APIs to handle callbacks. Functions like AJAX, setTimeout call these APIs.
Web APIs push callbacks into callback queue. Callbacks wait to be executed in the future.
Event loop watches call stack and callback queue. If call stack is empty, event loop takes one callback from callback queue and javascript engines executes the callback.

Queues

Callback queue is not only one but two queue: macrotask queue and microtask queue.
Everytime event loop is triggered, it takes all microtasks and one macrotask. Microtasks are executed first.
Macrotasks: setTimeout, setInterval, setImmediate, I/O operations, UI rendering
Microtasks: Promise, process.nextTick, MutationObserver

Markdown

Markdown

What is markdown ?

A lightweight markup language which formats content by its simple syntax.

Why markdown ?

  1. Eveywhere, for everything.
    Websites like Reddit, Github, etc. support markdown. Documents, notes, books, emails and so on support markdown. WYSIWYG files are mostly only supported by its own editor.

  2. Human readable. Markdown files are in plain text which is human readable. WYSIWYG files are not.

  3. Portable. As markdown files are written in plain text, it can be created on any device, any operating system. And almost all platforms supports rendering of markdown.

Kicking the tires

Online editor: Dillinger
Client editor: Marktext, a realtime rendering editor

Syntax

Basic

Element Syntax
Heading # Heading 1
## Heading 2
### Heading 3
Bold **bold text**
Italic *Italic*
Blockquote > blockquote
List 1. First Item
2. Second Item
3. Third Item
- First Item
- Second Item
- Third Item
Code `code`
Horizontal rule ---
Link [title](https://www.example.com)
Image ![alt text](image.jpg)

Extended

Element Syntax
Table | Syntax | Description |
| ———– | ———– |
| Header | Title |
| Paragraph | Text |
Note that there must be a blank line after the table.
Fenced code block ```{ firstname: ‘dongtian’, lastname: ‘chen’ }```

Use ``` [language] to specify code block language, for example ``` js to specify javascript. See supported language here
Footnote Here’s a sentence with a footnote. [^1]
[^1]: This is the footnote.
Definition List term
: definition
Strikethrough ~~The world is flat.~~
Task List - [x] Write the press release
- [ ] Update the website
- [ ] Contact the media
Emoji That is so funny! 😂
Highlight I need to highlight these ==very important words==.
Subscript H~2~O
Superscript X^2^

FAQ

  • Escaping
    Use backslash to escape most special characters.

  • Leading spaces
    Markdown does not support leading spaces before each paragraph. Use  (may have some problem with specific renderer like Hexo) or full-width space(a prettier solution) at the beginning.

  • Custom style
    Use html tags directly in markdown and style them with css.
    1
    2
    3
    4
    5
    6
    7
    > <div class="poetry">满堂花醉三千客,一剑霜寒十四州。</div>

    <style>
    .poetry {
    text-align: center;
    }
    </style>

  • Warning box
    The easiest way is to use emojis:
1
>  **If you are using mobile browser**: Be very careful here!

Use emoji to call user attention


  • Change line in blockquote
1
2
3
4
5
6
7
8
9
10
11
12
13
> Case 1
>
> 00:23
>
> 00:54
>
> &nbsp;
>
> Case 2
>
> 00:21
>
> 00:51

will produce:

Case 1

00:23

00:54

&nbsp;

Case 2

00:21

00:51

or an easier one(leave one space at the beginning of the second line and so on):

1
2
3
> line 1
line 2
line 3

will produce:

line 1
line 2
line 3


  • Highlight delete/add line in code

Use diff directive:

1
2
3
``` diff
- I like markup
+ I like markdown

gives:

1
2
- I like markup
+ I like markdown

  • Code block with filename
1
2
``` js, test.js
console.log('hello!')

gives:

test.js
1
console.log('hello!')

  • List in list/nested list

Use 2 or 4 spaces:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
# Unordered list

* Item 1
* Item 2
* Item 3
* Item 3a
* Item 3b
* Item 3c

# Ordered list

1. Step 1
2. Step 2
3. Step 3
1. Step 3.1
2. Step 3.2
3. Step 3.3
Git

Git

What is Git ?

A distributed version control system.

Why Git over SVN ?

  1. Github uses git. Most modern IT companies use git.
  2. Git is distributed, SVN is centralized. Git enables you to work and source control offline with your own repo.
  3. Most operations are done locally, so it’s fast.

How Git works

Git consists of 4 areas:

  1. Working Directory: Current working directory.
  2. Staging Area: Tracks and saves changes ready to commit.
  3. Local Repo: Repository on the disk.
  4. Remote Repo: Repository on the server.

Git areas

Concepts

  • HEAD: Current branch.

.gitignore file

Refs:

  1. Git ignore patterns
  2. gitignore

Patterns

Pattern Example matches Explanation
logs logs
logs/debug.log
logs/latest/foo.bar
build/logs
build/logs/debug.log
If you don’t append a slash, the pattern will match both files and the contents of directories with that name. In the example matches on the left, both directories and files named logs are ignored
logs/ logs/debug.log
logs/latest/foo.bar
build/logs/foo.bar
build/logs/latest/debug.log
Appending a slash indicates the pattern is a directory. The entire contents of any directory in the repository matching that name – including all of its files and subdirectories – will be ignored
logs/* logs/test.log(a file)
logs/test(a directory)
but not
logs/bar/hello.c(a file)
the asterisk in the pattern does not match “bar/hello.c” which has a slash in it.
logs/
!logs/important.log
logs/debug.log
logs/important.log
Wait a minute! Shouldn’t logs/important.log be negated in the example on the left? Nope! Due to a performance-related quirk in Git, you can not negate a file that is ignored due to a pattern matching a directory
logs/**/debug.log logs/debug.log
logs/monday/debug.log
logs/monday/pm/debug.log
A double asterisk matches zero or more directories.
logs/*day/debug.log logs/monday/debug.log
logs/tuesday/debug.log
but not
logs/latest/debug.log
Wildcards can be used in directory names as well.
logs/debug.log logs/debug.log
but notdebug.log
build/logs/debug.log
Patterns specifying a file in a particular directory are relative to the repository root. (You can prepend a slash if you like, but it doesn’t do anything special.)

FAQ

What is HEAD in git ?

The HEAD in Git is the pointer to the current branch reference, which is in turn a pointer to the last commit you made or the last commit that was checked out into your working directory.

Git reset

Ref

Suppose we have a branch master with A/B/C commits:
- A - B - C (master)

  • reset --soft B: Moves pointer to B; changes staged; run commit and will get a new commit as C
  • reset --mixed B: Default. moves pointer to B; changes remain but unstaged; run add and commit and will get a new commit as C
  • reset --hard B: Moves pointer to B; changes permanently reset; always run status to make sure changes can be discarded

Undo a commit

undo add: git reset
undo commit: git reset --hard HEAD~1 (moves to one commit before and --hard resets staging and working changes)

  • In existing directory, git init .
  • git remote add origin <remote repo url>(origin is a conventional name for remote repo)
  • git push origin <local branch name>

What is a leading slash in .gitignore ?

The leading slash anchors the match to the root.

How can I ignore everything but one file in a directory ?

Original Answer

1
git add -f Website\bin\Settings.json

What is fast-forward ?

Fast forward

Git pull and git fetch

  • Ref: Fetch vs pull
  • Git pull: Incorporates changes from a remote repository into current branch and then fast-forward/merge current branch.
  • Git fetch: If don’t want to fast-forward/merge, use this.
  • pull = fetch + merge

Branches

  • git branch
    Show all local branches, with current branch marked with an asterisk.

    1
    2
    * master
    Pages
  • git branch -r
    Show all remote branches.

    1
    2
    origin/HEAD -> origin/master  // Currently checked out branch, which is origin/master
    origin/master
  • git branch -a
    List all branches.

  • git branch newb
    Create new branch named newb.

  • git checkout newb
    Switch to branch newb.

  • git checkout -b newb
    Shorthand for git branch newb and git checkout newb.

  • git branch -d newb
    Delete local branch newb.