C#基础教程:第三章:方法与函数

1. 方法的定义与调用

方法是执行特定任务的代码块,可以被调用多次,从而减少代码重复,提高代码的可读性和维护性。

  • 方法的定义

    csharp 复制代码
    // 无返回值的方法
    void Greet() {
        Console.WriteLine("Hello, World!");
    }
    
    // 有返回值的方法
    int Add(int a, int b) {
        return a + b;
    }
  • 方法的调用

    csharp 复制代码
    Greet(); // 调用无返回值的方法
    
    int sum = Add(5, 3); // 调用有返回值的方法,并将返回值赋给变量sum
    Console.WriteLine(sum); // 输出:8
2. 参数与返回值

方法可以接受参数并返回结果。

  • 带参数的方法

    csharp 复制代码
    void PrintMessage(string message) {
        Console.WriteLine(message);
    }
    
    // 调用带参数的方法
    PrintMessage("Hello, C#!");
  • 有返回值的方法

    csharp 复制代码
    double Multiply(double x, double y) {
        return x * y;
    }
    
    // 调用有返回值的方法
    double result = Multiply(2.5, 4.0);
    Console.WriteLine(result); // 输出:10.0
  • 可选参数和参数默认值

    csharp 复制代码
    void DisplayInfo(string name, int age = 30) {
        Console.WriteLine($"Name: {name}, Age: {age}");
    }
    
    // 调用带可选参数的方法
    DisplayInfo("Alice"); // 输出:Name: Alice, Age: 30
    DisplayInfo("Bob", 25); // 输出:Name: Bob, Age: 25
3. 方法重载

方法重载是指在同一个类中可以定义多个具有相同名称但参数列表不同的方法。

  • 方法重载的示例

    csharp 复制代码
    void Display(int a) {
        Console.WriteLine($"Integer: {a}");
    }
    
    void Display(double a) {
        Console.WriteLine($"Double: {a}");
    }
    
    void Display(string a) {
        Console.WriteLine($"String: {a}");
    }
    
    // 调用重载的方法
    Display(5); // 输出:Integer: 5
    Display(3.14); // 输出:Double: 3.14
    Display("Hello"); // 输出:String: Hello
4. 递归

递归是方法调用自身的编程技巧,用于解决分解为类似子问题的问题。

  • 递归方法的示例
    • 计算阶乘

      csharp 复制代码
      int Factorial(int n) {
          if (n <= 1) {
              return 1; // 基本情况:n为1或更小
          } else {
              return n * Factorial(n - 1); // 递归情况:n * (n-1)!
          }
      }
      
      // 调用递归方法
      int result = Factorial(5);
      Console.WriteLine(result); // 输出:120
    • 斐波那契数列

      csharp 复制代码
      int Fibonacci(int n) {
          if (n <= 1) {
              return n; // 基本情况:n为0或1
          } else {
              return Fibonacci(n - 1) + Fibonacci(n - 2); // 递归情况:前两个数之和
          }
      }
      
      // 调用递归方法
      int fib = Fibonacci(6);
      Console.WriteLine(fib); // 输出:8
相关推荐
孤雪心殇16 分钟前
简单易懂,解析Go语言中的Map
开发语言·数据结构·后端·golang·go
隔壁老王15619 分钟前
mysql实时同步到es
数据库·mysql·elasticsearch
庸俗今天不摸鱼28 分钟前
Canvas进阶-4、边界检测(流光,鼠标拖尾)
开发语言·前端·javascript·计算机外设
菠菠萝宝29 分钟前
【Java八股文】10-数据结构与算法面试篇
java·开发语言·面试·红黑树·跳表·排序·lru
奔跑吧邓邓子32 分钟前
【Python爬虫(36)】深挖多进程爬虫性能优化:从通信到负载均衡
开发语言·爬虫·python·性能优化·负载均衡·多进程
不会Hello World的小苗35 分钟前
Java——链表(LinkedList)
java·开发语言·链表
想要打 Acm 的小周同学呀42 分钟前
Redis三剑客解决方案
数据库·redis·缓存
rkmhr_sef43 分钟前
Redis 下载与安装 教程 windows版
数据库·windows·redis
lsx2024061 小时前
Perl 面向对象编程指南
开发语言
Allen Bright1 小时前
【Java基础-46.3】Java泛型通配符详解:解锁类型安全的灵活编程
java·开发语言