Types Flashcards
What do the following mean:
- type equivalence
- type compatability
- type inference
- type clash
data:image/s3,"s3://crabby-images/2c06f/2c06f1e9ca66778d60e05fa037643c65e75ee4c5" alt=""
What is a strongly typed language?
data:image/s3,"s3://crabby-images/cc29e/cc29e3c3b04fe1e02c771e2c3f8f6f81693256d4" alt=""
What is a statically typed language? Examples?
data:image/s3,"s3://crabby-images/977cc/977cc92e9c9cf04f807c2b36d6395377bf3245a4" alt=""
What is a dynamically typed language? Examples?
data:image/s3,"s3://crabby-images/b1692/b16924b7b2300c146b5b66bb1ed4914915705174" alt=""
What is the difference between structural and name equivalence?
data:image/s3,"s3://crabby-images/e05f8/e05f8af8339cc7723c7e6264bfab1e8b32c7acd7" alt=""
Is the following an error? Think of equivalence
data:image/s3,"s3://crabby-images/09c7f/09c7f47c9b5e235bf92701ce268f85aa57815e82" alt=""
data:image/s3,"s3://crabby-images/0aa4b/0aa4b7cc1bd133b1b48b8ed1acdb7c6449f48f01" alt=""
What does name equivalence mean? Are aliases of differenent types the same?
data:image/s3,"s3://crabby-images/2e7af/2e7af86be18b60c7b72cf6c82b7d7bcd4562610c" alt=""
What are strict and loose name equivalences?
data:image/s3,"s3://crabby-images/cbc44/cbc447d7a6f176b5e39e10d0fa86317e9e739b2a" alt=""
What is the difference between type conversion and type coercion?
data:image/s3,"s3://crabby-images/d0b37/d0b373d4da9d5a355fa744abd5b790e24363cc91" alt=""
What is type compatability?
data:image/s3,"s3://crabby-images/6d1a4/6d1a48e37747c02afb654480f78f2ce05676e2b0" alt=""
What is type inference?
data:image/s3,"s3://crabby-images/de271/de27167cdb76e23914233ee9aad8bf86e12651be" alt=""
Example of type inference
data:image/s3,"s3://crabby-images/4b499/4b499c5f704b4b08c36631d86fcfc50214aa82f9" alt=""
What is polymorphism?
data:image/s3,"s3://crabby-images/6fe68/6fe68eba41fb81c86f0f71f2c95bd5b60e89b91e" alt=""
What are the 3 types of polymorphism and what do they mean?
data:image/s3,"s3://crabby-images/b80ca/b80cac840a2fb0e611004db5d9b2a2cc1ff0d956" alt=""
What is static allocation of arrays?
data:image/s3,"s3://crabby-images/364bf/364bfd9b97c1818fcc988673e86e5f4e34b3138a" alt=""
What is stack allocation of arrays?
data:image/s3,"s3://crabby-images/98e2a/98e2a6035210ea68ce3227589a4982dfe9706cff" alt=""
What is heap/stack allocation?
data:image/s3,"s3://crabby-images/79954/79954cf5f930b739897f972d2b9ce78c8010faa4" alt=""
What are sets and what are their implementations in CS?
data:image/s3,"s3://crabby-images/bdb9d/bdb9da84c88a451683f7895c22bfde6b73ecff72" alt=""
What are pointers?
data:image/s3,"s3://crabby-images/a0108/a0108dd9754b22455fb97e75fcc2ed1c5c6eccd7" alt=""
What are recursive types?
data:image/s3,"s3://crabby-images/08118/081186807268eb8a7ab71e165917ff9b9f95ab6b" alt=""
What is a dangling reference?
data:image/s3,"s3://crabby-images/46ca3/46ca3e37311277ad816a870283bae25ed658f2da" alt=""
What is garbage collection?
data:image/s3,"s3://crabby-images/2ad67/2ad67718c1b54d105bc9ee18762ed2523e95df40" alt=""
What are reference counts?
data:image/s3,"s3://crabby-images/c088a/c088a11dd7175870d85d6367fd7cb94ed4dcea9a" alt=""
Example of reference counts
data:image/s3,"s3://crabby-images/1cab8/1cab8366e5f34a36d57accb6ee520355c5dbafeb" alt=""
What is tracing collection / mark-and-sweep?
data:image/s3,"s3://crabby-images/f7878/f78788a909cc1701342540006f2125573fccea65" alt=""
What is stop-and-copy?
data:image/s3,"s3://crabby-images/6a55a/6a55a03b5b059680e84552e824e2fa061a4c6e8a" alt=""
Example of pointer reversal in mark-and-sweep
data:image/s3,"s3://crabby-images/275f5/275f5e326ae7f585665a7dd4e36f1cd4a305f014" alt=""