Skip to main content

CSt 338 - Week 2

This week involved learning about object-oriented programming, and writing a fun casino slot machine simulator for the weekly assignment. 

I thought the assignment was a good exercise in working with classes and objects, although personally if I had the freedom to completely change method signatures and control flow logic as I pleased I probably would've come up with a drastically different solution. Additionally, the software tester in me wrote a couple of unit tests for my own personal amusement that performed 20 - 40 spins randomly, along with random inputs of -10 to 100 as inputs. The unit tests worked fine as well as the manual inputs I used to test the program as well.

Object-oriented programming is great, but I have actually more experience working in languages that aren't based on object-oriented programming. My first programming language and class was C, and since then I've taken multiple classes in that language itself. I've written several basic programs in C and I've practiced working with pointers, allocating heap memory, and dereferencing pointers (which I've failed at many times as a beginner). Additionally, I've taken a class in an even lower level language, x86 assembly. I don't find x86 assembly in itself very difficult, but it is incredibly tedious even compared to something low level like C. My rule of thumb with x86 assembly is that "if it takes 2 lines of C code, it probably takes 8 in assembly." Additionally, I work around a couple of embedded systems developers who seem to know their registers and stack pointers like the back of their own hands. It's quite amazing to see them work with low level code sometimes.

The only experience I have with UML diagrams is reverse engineering them when working with schemas in MySQL workbench. Because I like to visualize things, I find them quite useful when working with complex projects or structures because it makes it easier to see how every piece fits together to make one or several end solutions work. 

Comments

Popular posts from this blog

The Final Journal

It's the end of a long, four year journey, and what a journey it has been. I never thought I could pull off finishing my second bachelor's degree four years ago when I first went to that introduction to programming class at my community college. I would like to thank all the friends I've made along the way and the people who have helped me through the last two years. Although it was difficult at times taking class while working 40+ hours a week, I'm proud of myself for making it through. I don't think I'll be a student enrolled in classes anytime soon, but I'll always be a lifelong student. See you all around.

CST 300 - Week 4

Educational Goals My current educational goals are to finish my bachelor's degree in computer science while also gaining a deep understanding of the fundamentals along the way. I have always believed that a solid understanding of the fundamentals goes a long way in any skill since you always refer back to them. When I have gotten stuck on a problem or some skill in the past, I have always taken a step back, broken down things into smaller pieces and remembered my fundamentals, and doing so has helped me through a lot of academic and professional work so far. Although I already know basic programming and data structures, I want to learn more about them and discover new ways of thinking in order to solve complex problems.  Career Goals I started a career as a full-time software test analyst about two months ago. Even though my job doesn't involve a lot of programming, getting a degree in computer science would be really helpful in all aspects of my career, such as identif...

CST 499 - Week 5

This week, our group completed a major milestone in our project by finishing the front end of our application, marking it as a "feature complete". We also conducted our initial round of user acceptance tests and received plenty of useful feedback, comments, and suggestions for the final stages of development and eventual deployment.  As a test engineer, I also interact with end customers doing software system test, so I understand quite well the process of conducting tests and then signing off said tests if they meet all requirements as specified. Since my company must comply with Department of Defense standards, the "rules of engagement" for testing and product acceptance are much stricter than our standards for capstone, but I can imagine similar rules would be applied to other students doing industry projects. Also, I got my first experience writing a test procedure from scratch by myself, as even at my job I am not responsible for writing procedures but I am acc...