博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[CS101] Operating System and Low Level Fundamental 操作系统及底层基础面试题
阅读量:6124 次
发布时间:2019-06-21

本文共 5160 字,大约阅读时间需要 17 分钟。

操作系统

进程与线程

What's the difference between thread and process?

A process is an instance of a computer program that is being executed. It contains the program code and its current activity. A process may be made up of multiple threads.

  1. Process are typically independent, while threads exist as as subsets of a process.

  2. Process has much more overhead than thread due to slower context switch

  3. PCB of processes carries more state information than TCB of threads

  4. All threads of a process share its virtual address space and system resources.

  5. Synchronization is more important in thread than process

  6. Processes interact only through system-provided inter-process communication mechanisms

How do processes communicate?

Cooperating processes require an inter process communication (IPC) mechanism that will allow them to exchange data and information.

  1. Shared memory

    A shared memory region resides in the address space of the process creating the shared memory segment. Other processes that wish to communicate using this shared memory segment must attach it to their address space.
    Examples: POSIX Shared memory

  2. Message passing

    It is particularly useful in a distributed environment. If process P and Q want to communicate, they must send message to and receive messages from each other. A communication link must exist between them.
    Examples: Mailboxes, ports, local/remote procedure call

  3. File

    Communicating with files is the most basic way to do inter-process communication.

How do threads communicate?

At the lowest level, threads communicate with each other by writing to the same memory location. To ensure that multiple threads do not write simultaneously at this memory location (causing race condition), various synchronization mechanism are used to enforce mutual exclusion such that allowing only one thread to access the data at a time.

网络

What is latency? What is throughput?

Latency is the time required to perform some action or to produce some result.Latency is measured in units of time -- hours, minutes, seconds, nanoseconds or clock periods.
Throughput is the number of such actions executed or results produced per unit of time. This is measured in units of whatever is being produced (cars, motorcycles, I/O samples, memory words, iterations) per unit of time. The term "memory bandwidth" is sometimes used to specify the throughput of memory systems.

What happens when you type in a URL in browser?

  1. Browser checks cache first, if requested object is in cache and is fresh, jump to 8

  2. Browser asks OS for server's IP address under that URL

  3. OS makes a DNS lookup and replies the IP address to the browser

  4. Browser initiates a TCP connection with the server

  5. Browser send a HTTP request to server

  6. Server handle the incoming request

  7. Browser receives the HTTP response and may close the TCP connection

  8. Browser determines what to do with response, cache, decode or render

分布式计算

What is the difference between Git and SVN?

  • GIT is distributed, SVN is not.

  • GIT stores content as metadata, SVN stores just files

  • GIT branches are not the same as SVN branches. Branches in SVN are nothing but just another Folder in the repository

  • GIT does not have a global revision no. like SVN do

  • GIT’s content integrity is better than SVN’s

计算机组织结构

存储器

What are big endian and little endian? How to tell whether a computer is big or little endian?

The decimal number 1025:

00000000 00000000 00000100 00000001

In memory, it is:

Address    Big-Endian      Little-Endian00         00000000        0000000101         00000000        0000010010         00000100        0000000011         00000001        00000000

We can tell it by checking the content in specific address:

int main(){    int x = 1;    char *y = (char*)&x;    printf("%c\n",*y+48);}

If it prints 1, then it is little endian. If it prints 0, then it is big endian. Because char will only occupy first byte.

How to represent a float in memory?

There're three sections while representing the float number: 1bit Sign Bit, 8bit Exponent and 23bit Significand

+-+--------+-----------------------+| |        |                       |+-+--------+-----------------------+ 0 10000100 11001001000011111100111 ^     ^               ^ |     |               | |     |               +--- significand = 0.7853975 |     | |     +------------------- exponent = 4 | +------------------------- sign = 0 (positive)

Sign bit: 0 indicates positive, 1 indicates negative

Exponent: Range of exponent is from -128 to 127. To be specific, 10000000 represents 0, 00000000 represents -128, 11111111 represents 127
Significand: Each bit represents a negative power of 2 counting from the left, if the significand is 01101, then the value should be:

$$ 01101=0\times 2^{-1}+1\times 2^{-2}+1\times 2^{-3}+0\times 2^{-4}+1\times 2^{-5} = 0.25+0.125+0.03125 = 0.40625 $$

What's the approximate time cost to access various storage?

1 ns        L1 cache        3 ns        Branch mispredict        4 ns        L2 cache       17 ns        Mutex lock/unlock      100 ns        Main memory (RAM)    2 000 ns (2µs)  1KB Zippy-compress   16 000 ns (16µs) SSD random read  500 000 ns (½ms)  Round trip in datacenter 2 000 000 ns (2ms)  HDD random read (seek)

转载地址:http://libua.baihongyu.com/

你可能感兴趣的文章
JS-原生代码或方法实现特定效果总结(更新中...)
查看>>
day05_MySQL学习笔记_02
查看>>
二次函数三点式
查看>>
《JavaScript 高级程序设计》第四章:变量、作用域和内存问题
查看>>
拒不承认违法?Uber就无人车上路问题与加州政府展开会谈
查看>>
学习汉语和学习编程的异同点
查看>>
自定义(带属性)标签学习笔记
查看>>
NET Core-学习笔记(四)
查看>>
Veeam 助力 Trend Micro 解决数据保护和灾难恢复挑战
查看>>
WebService就是这么简单
查看>>
Python对字典分别按键(key)和值(value)进行排序
查看>>
Java,Python,Scala比较(三)wordcount
查看>>
python爬虫学习:爬虫QQ说说并生成词云图,回忆满满
查看>>
《Java语言程序设计》大作业报告 九宫格游戏
查看>>
JS-检测浏览器类型及版本
查看>>
[20180316]异步IO和共享服务模式.txt
查看>>
nginx服务器架构(一):基本部署与启动
查看>>
1001号云制造现身2017 MWC,它可以远程操作国内3D打印设备集群
查看>>
快速的搭建JFinal的ORM框架示例
查看>>
ADM325 ECC6 的PA教材
查看>>