260 likes | 276 Views
Educational Influences of Choice of First Programming Language. Mirjana Ivanović, Zoran Budimac, Đura Paunić Department of Mathematics and Informatics Faculty of Science s , University of Novi Sad , Serbia. AGENDA. I ntroduction Characteristics of (first) Programming Languages
E N D
Educational Influences of Choice of First Programming Language Mirjana Ivanović, Zoran Budimac, Đura Paunić Department of Mathematics and Informatics Faculty of Sciences, University of Novi Sad, Serbia
AGENDA • Introduction • Characteristics of (first) Programming Languages • Different Language Paradigms and Approaches in Education • Usinge one PL for Core Programming Courses • Conclusion
Introduction • Is problem of choice of the first programming language a little bit out of date? • Especially for teachers who are not from PL community seems clear which language to choose. • It is not easy decision, burden with a lot of dilemmas. • Is the choice of the FPL serious for later development of a programmer?
Introduction • Important to distinguish key features of a PL in the context of education. • Practical difficulties in separating the educational issues of programming from the training issues of coding. • DILEMMA: are PLs important for students in all disciplines of computer science? • Disaster - introduction of objects before the basic programming constructs.
AGENDA • Introduction • Characteristics of (first) Programming Languages • Different Language Paradigms and Approaches in Education • Usinge one PL for Core Programming Courses • Conclusion
Characteristics of (first) Programming Languages • In Companies a lot of factors influence selection/usage of appropriate PLs and tools: • Computer capabilities, • Domains of applications, • Programming and Implementation methods, • Standardization. • ICT industry influences educational processes: • 1) Rapidly changing decisions which PLs and tools to use. • 2) Decision whether to use already available components and patterns?
Characteristics of (first) Programming Languages • Students have to be prepared for the real world of very complex software, stay around for a long time. • Programmers must be prepared to write (reusable) programs of hundreds of thousands of lines. • Additional influences on selection of PL: • Is there/what kind of teaching programming exist on secondary school level; • Students’ pre-knowledge and vision of their future jobs; • Requests of local industry; • Global-world trends in programming and influences of newest technologies.
Characteristics of (first) Programming Languages • List of criteria and attributes for choosing a first good PL: • Clarity, simplicity, and unity; • Orthogonality; • Naturalness for the application; • Support for abstraction; • Ease of program verification; • Characteristics of programming environment; • Portability of programs; • Cost of use; Reliability; • Maintainability; • Efficiency.
AGENDA • Introduction • Characteristics of (first) Programming Languages • Different Language Paradigms and Approaches in Education • Usinge one PL for Core Programming Courses • Conclusion
Different Language Paradigms and Approaches in Education • Numerous PL, several programming paradigms emerged: imperative, object-oriented, functional, and logic. • At majority of universities first two are predominant. • A new trend of teaching first programming course: Component-oriented approach. • Some teachers like to teach the most popular PLs, criteria?: Most widely used? Most lines of codes? Most jobs? Most courses/projects? • Is popularity of a language a guarantee of its quality and suitability? • Expectedly there is no best language for all situations.
Different Language Paradigms and Approaches in Education • Possible Solution?: Teaching Programming Using Pseudo-Language • Essential directions in teaching programming, teach students how to solve problems without focusing on coding in particular PL. • Idea is to develop their algorithmic and critical thinking and concentrate on different techniques for problem solving. • Is it meaningful to go back to the roots and concentrate in introductory programming courses on: • essence of problem solving, • algorithmic thinking • core principles.
Different Language Paradigms and Approaches in Education • Our Model/Proposition for Teaching First Programming Language • Proposition and successful model? We gave up!!! • To teach students to think in algorithmic way and to make good programs. • To use a good educational (like Pascal, Delphi, Modula) language. • After that students have course on data structures and algorithms, ready to learn object-oriented style in Java. • By our experience there are several advantages of this approach: • In first 3 semesters students are learnt to think in logical, algorithmic way and to reach efficient solutions. • After that, by learning Java they further develop their programming skills and new techniques.
AGENDA • Introduction • Characteristics of (first) Programming Languages • Different Language Paradigms and Approaches in Education • Usinge one PL for Core Programming Courses • Conclusion
Using one PL for Core Programming Courses Modula-2 has been teaching up to now at our Department as it satisfies most of the desirable premises: • Most of the students have pre-knowledge of Pascal so Modula-2 is convenient for them. • It offers clean and well-structured features and elements. • It is satisfactory language for teaching other classical methodologies, techniques and algorithms. • After finishing obligatory studies, students can easily switch to object-oriented methodology.
Using one PL for Core Programming Courses • Computer study in Serbia, DMI, began about 35 years ago • Almost all CS courses • Began with teaching some particular programming language. • Smaller amount of time was devoted to teaching main subject of concrete course. • Waste of time? .
Using one PL for Core Programming Courses • Last 20 years the study of CS at DMI • Lasts four years. • Several interconnected core courses in programming: • KEY/ESSENTIAL programming courses, use the same PL • Introduction to programming(first semester) - basic concepts of imperative programming, recurrence and recursion, and simple abstract data types (ADT). • Data structures and algorithms 1 and 2(second and third semester) - concepts of ADT, different data structures (lists, stacks, queues, trees, graphs), and various algorithms (sorting and searching, combinatorial and graph algorithms). • Operating systems 1(fifth semester) - basic principles of operating systems: processes, low-level programming, and interaction of programs with operating system. • Compiler construction (seventh semester) - principles and techniques of compiler construction (formal grammars, recursive descent, top-down, bottom-up analysis), structuring of big programs, type analysis and code generation are presented.
Using one PL for Core Programming Courses • Main intention: • Emphasize on ADS. • Not to insist on particular realization in specific programming language or to use different languages in different courses. • Avoid teaching many languages or various frameworks/environments: • Choose one good educational language, easy to teach , good for development of correct programming style. • Language should be rich enough to support modern concepts of software development. • First programming language serves as a reference for learning additional programming languages.
Using one PL for Core Programming Courses • Modula-2 was • Very good language for educational purposes (supports many concepts appreciated in software engineering). • Provides an adequate number of facilities and it is suitable to be thought as one "major“ PL throughout the whole computer science education: • Allows to teachers to put attention to data structures, algorithms, and principles rather than to teach new programming language. • It is expected (is proven in practice) that students will easily learn other PL, once they know the essence of programming techniques. • After four-year study the students are well equipped to cope easily with other industrial and business languages as C, C++, COBOL, Java or fourth generation languages
Using one PL for Core programming Courses • Need for changes? • Advantages of that concept • Structured programming concepts have strongly affected programming language. • Modularity, encapsulation of data and behavior, information hiding are concepts that influenced language development. • Postulate strict, static typing of every variable and function, significant to teach students to write safe, robust, reusable software. • Strongly typed language - most possible errors in programs are eliminated only following these requirements. • Modula-2 enable to create programs which make testing and debugging easier. Students are well experienced and easily can be capable to use other different programming language tools, environments, frameworks and so on.
Using one PL for Core programming Courses • Need for changes • Modula-2 is out of date? Replacement? • Not used in industry and companies. • Need for modern programming tools and environments that support other PL. Suitable for teaching programming? • Everyone is expert: students, parents, friends, non-CS-professors,… • Opportunity to attract more high-quality students. • Marketing or real need?
AGENDA • Introduction • Characteristics of (first) Programming Languages • Different Language Paradigms and Approaches in Education • Usinge one PL for Core Programming Courses • Conclusion
Conclusion • At the beginning students • are not satisfied with choice of first PL – • prefer Java or C-like languages (request of local industry). • After the second year (OO programming with Java) they appreciate presented model: • With educational language they adopted good style of programming • Knowledgeable and skilled to cope with Java complexity and instability. • A lot of our ex-students working in software companies all over the world agree that proposed model was very productive.
Conclusion • Debates about choice of FPL are never-ending stories. • Pressures of our local CS policy makers were enormous. • Java has emerged as the language of the choice (C like languages were candidates). • Nevertheless there is no universal satisfaction with Java as a teaching language.
Conclusion The rate at which computer technology and programming languages changes with time now is alarmingly higher than was seen in the past. Rapid changes in computer technology and PLs have to be kept in mind, by continuously re-evaluating language choice issues. Computer industry re-tools more frequently and programmers will cover many more languages in their lifetime than ever before. This implies that while learning practical programming skills in a particular PL, it is even more important for the novice programmer to develop a sound theoretical understanding of programming in general … to prepare for later learning future languages and environments. Changing education patterns means that students needs be prepared for lifelong learning, to meet the challenges of the future.
Conclusion Choice of the FPL for CS education is difficult and responsible task (a lot of programming paradigms, compete for widely used language in industry and real world applications). Education has to follow these trends, but also has to satisfy other (methodological, didactical,...) parameters. Once students learn good programming style and master programming techniques they can much easier learn and use industry-forced languages: C, C++, COBOL, Java, … We are heavily exposed to constant pressure of industrial and labor requirements to have employees tailored to their current needs and business (oriented to contemporary technologies and programming environments, employees could immediately fit in their business and produce software/money). Unfortunately it seems that nobody takes care about fundamental and essential knowledge and people capable of quickly switch to new technologies and trends.