Javase 第三周笔记

Javase 第三周期笔记

图片上传失败故粘贴为纯文本
函数

2021年1月18日
11:22

1.函数的语法格式
函数的书写
修饰符 函数类型 返回值类型 函数名(数据类型 数据1,数据类型 数据2,…)
{
独立功能的代码片段;
return 函数的计算结果;
}

修饰符:指的是函数的访问权限,public private 默认 protected
函数类型:
本地函数native
静态函数static
同步函数 synchronized
返回值类型:
如果函数没有返回值 则为void
函数名:就是函数的名称
参数列表:指的是外界向函数传入的数据(实际参数),由这些参数变量进行接收(形参)
函数体:具有独立功能的代码片段;
return:
仅仅表示函数结束
如果函数有返回值,则return后跟返回值
如果没有返回值,则return可以不写,但是是存在的隐藏的

根据形参和返回值来看,函数有如下几个分类
有参数有返回值

有参数无返回值

无参数有返回值

无参数无返回值

2.函数的运行原理

函数的运行是基于栈运行的
栈:是一种先进后出的容器,这里面所说的栈是指JVM中的栈内存空间
每一个函数,叫做栈帧,栈帧中所包含的内容有函数的定义,参数列表,函数的执行内容代码
一个函数要运行,就相当于这个栈帧进入到栈内存中-入栈
一个函数即将结束,将这个栈帧从栈顶移出-出栈

如果栈内存中有多个栈帧,先运行的是最上面的栈帧,底下的栈帧暂停运行,直到该栈帧到栈顶

  1. 函数重载
    同一个类中可以出现多个同名函数,这个现象就叫做函数的重载
    如何来区分同名函数是否是重载关系
    必须是同名,和返回值类型无关(返回值类型只和函数的计算功能相关)
    和权限也没有关系,和形式参数的名称也无关
    只和形式参数有关 包括参数类型不同,数量不同,位置不同

寻找重载函数的流程:

  1. 看是否有确切的参数定义匹配
  2. 看是否有可兼容的参数定义匹配
  3. 如果可兼容的参数定义匹配较多,会报引用确定报错 引用不明确

4.函数递归
函数的递归就是指函数自身调用自身。
但凡迭代能够解决的问题,递归都可以解决;递归能够解决的问题,迭代不一定能
相对而言,从内存的角度而言,函数如果过多的自我调用,势必会对占用更多内存
通常来讲,同样的问题用递归写要比用迭代写代码量较少
写递归时,一定要先确定递归结束条件-递归边界
public class Sample
{
public static void main(String[] args)
{
public static void test(int n)
{
System.out.println(n);
if (n == 1)
{
return;
}
else
{
test(n - 1);
}
}
public static void show()
{
System.out.println(“Hello!”);
show();
}
}
}

Demo68
import java.util.Scanner;
public class demo68
{
public static void main(String[] args)
{
Scanner scanner = new Scanner(System.in);
System.out.print(“Enter a number:”);
int number = scanner.nextInt();
System.out.println(isPalindrome(number));
}
public static boolean isPalindrome(int number)
{
int revNumber = reverse(number);
return number == revNumber;
}
public static int reverse(int number)
{
int result = 0;
while (number != 0)
{
result = result * 10 + number % 10;
number /= 10;
}
return result;
}

Demo67
import java.util.Scanner;
public class demo67
{
public static void main(String[] args)
{
Scanner input = new Scanner();
long shuzi = input.nextInt(System.in);
System.out.println(sumDigits(shuzi));
private int sumDigits(long shuzi)
{
int sum = 0;
int weishu;
while(shuzi != 0)
{
weishu = shuzi % 10;
shuzi = shuzi / 10;
sum += weishu;
}
return sum;
}
}
}

Demo81
public class demo81
{
public static void main(String[] args)
{
String x = “x”;
String y = “y”;
String z = “z”;
hano(3,x,y,z);
}
public static void hano(int level,String begin,String mid,String end)
{
if (level == 1)
{
System.out.println(begin+"->"+end);
}
else
{
hano(level - 1,begin,end,mid);
System.out.println(begin+"->"+end);
hano(level - 1,mid,begin,end);
}
}
}

Demo74
public class demo74
{
public static void main(String[] args)
{
int number = 2;
int count = 0;
while (count < 100)
{
if (isSuShu(number) && isHuiWen(number))
{
System.out.print(number + “\t”);
count++;
if (count % 10 == 0)
{
System.out.println();
}
}
number++;
}
}
public static boolean isHuiWen(int number)
{
int revNumber = reverse(number);
return revNumber == number;
}
public static int reverse(int number)
{
String str = “”;
while (number != 0)
{
str = str + number % 10;
number /= 10;
}
return Integer.parseInt(str);
}
public static boolean isSuShu(int number)
{
for (int i = 2 ; i <= number / 2; i++)
{
if (number % i == 0)
{
return false;
}
}
return true;
}
}

在这里插入图片描述
在这里插入图片描述

这个错误是由于无法连接到本地主机的10248端口导致的。这个端口通常是kubelet进程监听的端口,用于健康检查。出现这个错误可能是由于kubelet进程没有正确启动或者配置错误导致的。 解决这个问题的方法是检查kubelet进程的状态和配置。你可以按照以下步骤进行操作: 1. 检查kubelet进程是否正在运行。你可以使用以下命令检查kubelet进程的状态: ```shell systemctl status kubelet ``` 如果kubelet进程没有运行,你可以使用以下命令启动它: ```shell systemctl start kubelet ``` 2. 检查kubelet的配置文件。你可以使用以下命令查看kubelet的配置文件路径: ```shell kubelet --kubeconfig /etc/kubernetes/kubelet.conf --config /var/lib/kubelet/config.yaml --bootstrap-kubeconfig /etc/kubernetes/bootstrap-kubelet.conf config view ``` 确保配置文件中的端口号和地址正确,并且与你的环境相匹配。 3. 检查网络连接。你可以使用以下命令检查是否可以连接到localhost10248端口: ```shell curl -sSL http://localhost:10248/healthz ``` 如果无法连接,请确保端口没有被防火墙或其他网络配置阻止。 4. 检查docker的配置。有时候,kubelet进程依赖于docker进程。你可以按照以下步骤检查docker的配置: - 创建/etc/docker目录: ```shell sudo mkdir /etc/docker ``` - 编辑/etc/docker/daemon.json文件,并添加以下内容: ```json { "exec-opts": ["native.cgroupdriver=systemd"], "log-driver": "json-file", "log-opts": { "max-size": "100m" }, "storage-driver": "overlay2", "storage-opts": [ "overlay2.override_kernel_check=true" ], "registry-mirrors": ["https://tdhp06eh.mirror.aliyuncs.com"] } ``` - 重启docker进程: ```shell systemctl restart docker ``` 请注意,以上步骤是一种常见的解决方法,但具体解决方法可能因环境而异。如果以上步骤无法解决问题,请提供更多的错误信息和环境配置,以便我们能够更好地帮助你。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值