Names, Scopes, Binding, and Control Flow Flashcards
What is the main driving force behind the design of modern languges?
Ease of programming
High level programming is more a______
Abstract
Abstraction means that complexity becomes
Manageable
What do the following mean:
Name
Binding
Scope
Binding Time
data:image/s3,"s3://crabby-images/6e3ff/6e3ffd46d1c47a51d169bbc27480ed96342c765f" alt=""
What is static binding vs dynamic binding?
data:image/s3,"s3://crabby-images/304cb/304cb1c3ba501e75abff2f1e845b6ffb340cdca1" alt=""
Early binding times have greater ____
Late binding times have greater _____
Early binding times: greater efficiency
Late binding times: greater flexibility
What is the difference between compiled and interpreted languages?
data:image/s3,"s3://crabby-images/d7dd2/d7dd2943ed4900bfbfce2f8faaa85bf9c9c3199e" alt=""
What is the lifetime of name-to-binding?
data:image/s3,"s3://crabby-images/ae377/ae377e96bb7135682ef298cfd81e1c77cda2c6b9" alt=""
What is a dangling reference?
When the object’s lifetime is less than the binding’s lifetime
What is the scope of a binding?
The textual region of the program in which the binding is active
What is the difference between the following storage allocation mechanisms:
Static
Stack
Heap
data:image/s3,"s3://crabby-images/3427c/3427c69ea64afd23c0f180be9bc6b23825c4d403" alt=""
What is static allocation
data:image/s3,"s3://crabby-images/e5149/e514930da3bb68904149c96cfe06e25cc29e810f" alt=""
What is stack-based allocation?
data:image/s3,"s3://crabby-images/981b8/981b8583c60e5d455bc2ddd42d48797be0a16603" alt=""
What is a Frame for a subroutine call?
data:image/s3,"s3://crabby-images/da9d7/da9d7e97942c8994a3d6586ffdda591914702ce0" alt=""
What is heap allocation?
data:image/s3,"s3://crabby-images/f5ac3/f5ac36f3429b490f0805c9ef8b50b76b615c0ee5" alt=""
For heap allocation, what are the differene between the following allocation algorithms:
first fit, best fit
pool allocation
data:image/s3,"s3://crabby-images/a2f01/a2f01a8faac49494d9f94b25a9da8657fc963c70" alt=""
Examine some of the differences between explicit deallocation and implicit deallocation?
data:image/s3,"s3://crabby-images/28727/2872709b0f1ee5a4d5743f84e91b3826fcaf21c9" alt=""
What is a subroutine entry?
data:image/s3,"s3://crabby-images/1029d/1029dcd37c193f4c6ed650cde655d6124b2ee942" alt=""
What is a subroutine exit?
data:image/s3,"s3://crabby-images/33217/33217fb2db9efdc6f3fc32557a88d0ea2ce8d5a1" alt=""
What is a referencing environment?
data:image/s3,"s3://crabby-images/89294/8929465ad266f32e29b8e96fd96c19631cb2e0dd" alt=""
What is static scoping?
data:image/s3,"s3://crabby-images/9c7a6/9c7a65d48791b72a900a108af7b783827b875aa4" alt=""
What are some important things for scope rules
data:image/s3,"s3://crabby-images/5b5be/5b5bef28a0a2e81c7b3b6885914e3c6e921a2eab" alt=""
Examine the following nested subroutine graphic:
data:image/s3,"s3://crabby-images/a4c63/a4c6379f67f62db18d2bca9e00d0db724ad89e65" alt=""
What are static links?
data:image/s3,"s3://crabby-images/f338c/f338c9a860c46ea7e29c6e331dd24b84017ae9d0" alt=""
What is declaration order?
data:image/s3,"s3://crabby-images/a10a8/a10a8984ff46e455e6d45ec21017176895450423" alt=""
Examine the following examples for declaration order:
data:image/s3,"s3://crabby-images/053db/053dbf0b22ed55df763827ad774321782d1feebe" alt=""
What is dynamic scoping?
data:image/s3,"s3://crabby-images/9070a/9070acf2447358f691aa9c227cec2bb073ab2271" alt=""
Examine the following dynamic scoping examples;
data:image/s3,"s3://crabby-images/3edef/3edef8f2df29e97f115208890ed911c80c6b3273" alt=""
What is a referencing environment?
data:image/s3,"s3://crabby-images/3bd44/3bd442392d335526e4e706b70d0df7f1e3775ac8" alt=""
What is shallow binding vs deep binding?
data:image/s3,"s3://crabby-images/51f26/51f26c80376941b829bdee56efdc8753203b526a" alt=""
What is subroutine closure?
data:image/s3,"s3://crabby-images/d4eba/d4eba7539b6275697881b140838817f83f4cc7f3" alt=""
Why does binding time matter with static scoping?
data:image/s3,"s3://crabby-images/df6f7/df6f7f1965520541a3f98959cb23cf4474763916" alt=""
Consider the following deep binding example:
data:image/s3,"s3://crabby-images/af61f/af61ff36f1b48c8067855d8f2eb6399adfd0bc2a" alt=""
What are the following:
First-class values
Second-class values
Third-class
data:image/s3,"s3://crabby-images/70244/702440d72a05de70bdb9f94e742ff83e489b753d" alt=""
Examine the following with regards to first-class subroutines:
data:image/s3,"s3://crabby-images/17a81/17a81255d52e508f2563c97c82cb68176fc623e8" alt=""
What are lambda expressions?
data:image/s3,"s3://crabby-images/9eb72/9eb7286a2d798ea27395c19c0dc8afa54f1e94c2" alt=""
Examine the following lambda function examples:
data:image/s3,"s3://crabby-images/476bb/476bb48c7a518f17c07a6c8f4a5ba3ef3d6f798f" alt=""
What is sequencing’s role in imperative and functional languages?
data:image/s3,"s3://crabby-images/ffcd7/ffcd7f0d903044e73be6d262b1fa0a48217a8802" alt=""
What is recursion’s role in imperative and functional languages?
data:image/s3,"s3://crabby-images/12a39/12a39d68971d99583aa8abe979a61d92bd0e835e" alt=""
Does logic programming have control flow
data:image/s3,"s3://crabby-images/44857/44857e2039d96956fa9f029ef79d31a0fcaab7d4" alt=""
What are the differences between:
prefix
postfix
infix
data:image/s3,"s3://crabby-images/67690/6769050cec5ce451d23f5d6b3be33c539567024b" alt=""
What is the difference between the value model and the reference model?
data:image/s3,"s3://crabby-images/e213e/e213e330bf07b1c84ee4c51430118b2440dc887d" alt=""
What are the following:
- call by value
- call by reference
- call by sharing
- call by name
- call by need
data:image/s3,"s3://crabby-images/800ee/800ee87c18d09d5c77adb3a5a39a155c41f09def" alt=""
What is short circuiting?
data:image/s3,"s3://crabby-images/306eb/306eb526e4bd624c3c98a0c973affbd822946626" alt=""
Is recursion generally more efficient that iteration?
No
What type of recursion is as fast as iteration? How?
data:image/s3,"s3://crabby-images/67395/67395eee93cb6c22983f724a93db15936dc9a2cf" alt=""
What is applicative evaluation order?
data:image/s3,"s3://crabby-images/de184/de1844ccb82765e65c7d00ac4997869ceba4b95b" alt=""
What is normal-order evaluation order?
data:image/s3,"s3://crabby-images/bbd1e/bbd1e57a3244412f991ea6c02dd03b41965b099d" alt=""
What is lazy vs strict evaluation?
Lazy evaluation stops evaluating params when it knows the result:
data:image/s3,"s3://crabby-images/4522d/4522d4dbb29a3c8870a1674090bac537c66c5bcb" alt=""