Mark Pearl

The Basics

Types

Regex Type

Basic use…

m = /.*/.match("some input text")

Converting Types

  • to_s converts to string
  • to_i converts to integer
  • to_a converts to array

Working with Variables

Exlamation Points - methods may have exclamation points in their name, which just means to impact the current data rather than making a copy.

Scope or variables

$ a global variable
@ an instance variable
[a-z] or _ a local variable
[A-Z] a constant
@@ a class variable

Operators

Tenary Operator

() ? … : …

x = 1
(x == 1) ? "one" : "other"

Equivalent to…

x = 1
if (x == 1) then "one" else "other" end

Spaceship Operator

… <=> …

x = -50
y = 32
return x <=> y    # return -1

Instead of returning 1 (true) or 0 (false) depending on whether the arguments are equal or unequal, the spaceship operator will return 1, 0, or −1 depending on the value of the left argument relative to the right argument.

given

a <=> b 

if a < b then return -1
if a = b then return 0
if a > b then return 1
if a and b are not comparable then return nil


Comparisons

Case

value = 1

return case value
    when 1 then "One"
    when 2 then "Two"
    when 3 then "Three"
    else "Other"
end

Working with Strings

Convert String to Array

text = "hello"
text.split("") # ['h','e','l','l','o']

alternatively…

text = "hello"
text.chars() # ['h','e','l','l','o']

Slicing

 array[index]                -> obj      or nil
 array[start, length]        -> an_array or nil
 array[range]                -> an_array or nil
 array.slice(index)          -> obj      or nil
 array.slice(start, length)  -> an_array or nil
 array.slice(range)          -> an_array or nil
 array.take(n)               -> an_array

Checking variable is an array

def doSomething(list)
    list.kind_of?(Array) ? "Is an Array" : "Is something else"
end

Substitute / Replace Regex Match

Performs substitution of text inline.

"some text".gsub(/text/,'foo') # returns 'some foo'
"123456789".gsub(/[1-5]/, 'X' # return XXXXX6789

String Interpolation

num_cars = 10
msg = "I own #{num_cars} cars."

Chomp

"hello".chomp("llo")    #=> "he"
"hello\r\n".chomp()     #=> "hello"
"hello\r".chomp()       #=> "hello"

Working with Arrays

Basic declaration

values = [1, 2, 3]          # declares a simple array
maxValue = [1, 2, 3].max    # gets the largest value 

Basic access

values = [2, 4, 6]          # declares a simple array
values.at(0)                #=> 2
values.at(1)                #=> 4

Enumerable Methods

Select

Returns an array containing all elements for which the given block returns true

[1, 2, 3, 4, 5].select {|n| n % 2 == 0}  # Should return [2, 4]

Each / Each_with_index

[1, 2, 3].each { |num| print "hello #{num}! "}
[1, 2, 3].each_with_index { |element, index| print "hello #{num}! "}

Does the funciton on each element in the array and then returns the ORIGINAL array

Collect / Map

[1, 2, 3].collect { |num| num*num } # returns 1, 4, 9
[1, 2, 3].map { |num| num*num }     # returns 1, 4, 9

Sorting

arr = ['cab', 'abc', 'bca']
arr.sort_by { |i| arr[i] }   # ['abc', 'bca', 'cab' ]

Or…

arr = ['cab', 'abc', 'bca']
arr.sort {|a,b| a<=>b }      # ['abc', 'bca', 'cab' ]

Inject / Reduce

[1, 2, 3].reduce(0){|running_total, item| running_total + item} # returns 6

Alternatively…

[1, 2, 3].inject(0){|running_total, item| running_total + item} # returns 6

Alternatively…

[1, 2, 3].inject(0, :+) # returns 6

Dividing Arrays into Groups (Partition)

[1, 2, 3, 4, 5].partition {|n| n % 2 == 0} # Should return [[2, 4],[1, 3, 5]]

Comparing Array Differences

x = [1, 1, 2, 4]
y = [1, 2, 2, 2]

# intersection
x & y            # => [1, 2]

# union
x | y            # => [1, 2, 4]

# difference
x - y            # => [4]

Other

Colon-Plus, Colon-Star

Colon-Plus, Colon-Star are symbls

[1, 2, 3].inject(:+) # Equivalent to [1,2,3].inject(0){|total, num| total + num} 
[1, 2, 3].inject(:*) # Equivalent to [1,2,3].inject(0){|total, num| total * num} 

Dictionaries / Hashes

Pairs up a key with a value.

Basic declaration

object = {}                 # declares an empty hash
object = Hash.new(0)        # another way to declare a empty hash
object['key'] = :aValue     # adds a value with key with the symbol :aValue

Two Dimensional Arrays

Flatten them…

[[1,2,3],[4,5,6],[7,8,9]].flatten() # returns [1,2,3,4,5,6,7,8,9]

Working with Symbols

Loops

hashExample = {}
hashExample['key1']=:value1
hashExample['key2']=:value2
hashExample.values.each { |value| newHash[value] += 'set value'}

hashExample # {:value1=>"set value", :value2="set value"}

Classes

class TheClass
end

Class names start with a capital letter and use CamelCase

Initialization / Constructors

class TheClass
    def initialize(name, age)               # Equivalent to constructor
        @name = name
        @age = age
    end
end

instanceObject = TheClass.new("Mark", 36)   # Newing up an instance

Inheritance

Ruby can only have single inheritance, multiple inheritance is not supported. Inheritance is for reusing functionality, not enforcing interfaces.

class ParentClass
    def DoSomething()
    end
end

class InheritedClass < ParentClass
    def DoSomething()
        super.DoSomething()
    end
end

class AnotherInheritedClass < ParentClass
end

Class Methods

class TheClass
    def self.methodToCall
        2
    end
end

TheClass.methodToCall

#### Class Variables

- denoted with @@  
- are not used often  
- class variables are shared across all inherited classes

class TheClass
    @@classVariable = 2
end

Class Instance Variables

class TheClass @classInstanceVariable = 2

def self.classInstanceVariable
    @classInstanceVariable
end  end 

TheClass.classInstanceVariable

Method Visibility

class TheClass
    private def privateMethodName
    end
end

Open Classes

class TheClass
    def Method1
    end
end

class TheClass
    def Method2
    end
end

Is equivalent to…

class TheClass
    def Method1
    end
    
    def Method2
    end
end

Instantiation

let newInstance = className.new

Monkey Patching

Google it…

Equality

Custom equality on objects can be achieved using ==(other) syntax…

class TheClass
    attr_reader :name

    def initialize(name)
        @name = name
    end

    def ==(other)
        name == other.name
    end
end

Shallow copy of objects

b = a.clone

Instance Variables

class TheClass
    ...
    def method(variableParam)
        @instanceVariable = varialbeParam
        ...
    end
end
  • Instance variables are private by default
  • Instance methods are public by default

Accessors

class TheClass
    attr_accessor: instanceVariable
end

An accessor does the equivalent code

class TheClass
    def instanceVariable
        @instanceVariable
    end

    def instanceVariable=(new_value)
        @instanceVariable = new_value
    end
end

Working with Ruby Hashes

A hash is a collection of key value pairs. It is similar to an array, except that indexing is done via arbitrary keys of any object type, not an integer index.


Working with Blocks

Multi Line Blocks

def blockName
    [1, 2, 3].each do 
    print "hello"
end

Single Line Blocks

[1, 2, 3].each { |element| print "hello" }

Executing passed blocks

def count (list, &block)
	list.count(&block)
end

list = [0,1,2,3,5,8,13, 13]
count(list,{|item| item == 13})

or

def max list, &block
    list.max{|a,b| block.call(a,b)}
end

max(list){|a, b| a <=> b}

Check if block is given

def compute(&block)
    if (block_given?)
        puts "defined"
    else
        puts "not defined"
    end
end

Read blocks demystified
Read about using blocks


Installation

Updating Ruby in Ubuntu

rbenv is a tool for installing versions of ruby. To install rbenv use the following:

sudo apt-get install rbenv

To use rbenv here are some common commands:

rbenv install 2.2.3
rbenv use 2.2.3
ruby -v

References

Official Ruby Documentation
Ruby Online Repl



Want to get my personal insights on what I learn as I learn it? Subscribe now!


/