Retrun语句的用法及main函数简介

return语句的位置是自由的,无论它是处于哪一个位置都代表退出函数。

#include<stdio.h>
int is_aphlet(char ch){
	if(ch>='A'&&ch<='Z'){
		return 1;
	}
	else if(ch>='a'&&ch<='z'){ //'a'相当于是一个数字 
		return -1;
	}
	return 0;
} 
int main(){
	printf("%d\n",is_aphlet(71));
	return 0;
} 

main函数又称程序的入口,程序必须有一个main函数,从main函数开始按逻辑开始一行一行的执行。

//打印字母的ASCCI码 
#include<stdio.h>
int is_aphlet(char ch){
	if(ch>='A'&&ch<='Z'){
		return 1;
	}
	else if(ch>='a'&&ch<='z'){
		return -1;
	}
	return 0;
} 
void print_ascii(){
	for(int i=0;i<=127;i++){
		if(is_aphlet(i))
		{
			printf("%d->%c\n",i,i);
		}
	} 
}
int main(){
	print_ascii();
	return 0;
} 

 

如果你封装的节流和防抖函数返回后面的函数没有执行,可能是因为在封装的过程中没有正确处理函数的执行逻辑。以下是一个修复的示例: ```typescript // utils/debounce.ts export function debounce(func: Function, delay: number) { let timer: NodeJS.Timeout | null = null; return function(...args: any[]) { if (timer) { clearTimeout(timer); } timer = setTimeout(() => { func.apply(this, args); }, delay); }; } // utils/throttle.ts export function throttle(func: Function, delay: number) { let timer: NodeJS.Timeout | null = null; let lastRun = 0; return function(...args: any[]) { const currentTime = Date.now(); if (!timer) { func.apply(this, args); lastRun = currentTime; return; } if (currentTime - lastRun >= delay) { func.apply(this, args); lastRun = currentTime; } }; } ``` 在上面的示例中,修复了防抖函数和节流函数的返回逻辑。 对于防抖函数,当延迟时间内再次触发时,会先清除之前的定时器,然后重新设置定时器。这样可以确保只有最后一次触发的定时器会执行回调函数。 对于节流函数,初始状态下,如果没有定时器存在,则立即执行回调函数。如果已经存在定时器,则根据当前时间与上次运行时间的差值判断是否达到节流时间间隔,如果满足条件,则执行回调函数。 请注意,以上示例是基于Node.js环境下的实现,如果你在浏览器环境中使用,请适当调整定时器的类型和清除方式。另外,确保你正确使用这些封装的函数,并传递正确的参数和回调函数
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值