函数(易错)

函数传递数组,指针时候,传递的只是起始地址。

例:1维数组求和

 发现,求的数组大小,等于2?而不是5?

解释一下2是怎么来的:因为我的是64位机,而sizeof(int)大家都知道,4字节,32位;所以sizeof(p),应该就等于8字节,64bit;为什么是64bit?因为第一句话我就说了:函数传递数组,指针时候,传递的只是一个地址,64位机的地址,不就是64bit嘛。

所以,要把数组(指针)的大小,也要以形参的形式传递到函数里面来。

--------------------------------------------------------------------------------------------------------------------

字符数组,由于末尾有'\0',所以有时候传参时候可以不需要传数组大小

例:删除字符串中的空格

在Python中,并不存在名为`pythonsum`的内置函数,通常我们讨论的是`sum()`函数。`sum()`是一个用于计算序列(如列表、元组或集合)内所有元素总和的高阶函数。以下是使用`sum()`时的一些常见易错点: 1. **传递非数字**:如果将非数字类型的元素传递给`sum()`, 它会抛出TypeError。例如,尝试求字符串或None的和会失败,应该确保传入的是数字类型。 ```py # 错误示例 sum("hello") # TypeError: unsupported operand type(s) for +: 'int' and 'str' ``` 2. **空容器**:对空的列表或元组调用`sum()`会返回0,但如果期望的是`None`,则需要特别处理这种情况。 ```py sum([]) # 输出:0 ``` 3. **迭代器或生成器**:虽然`sum()`可以接受迭代器作为参数,但如果在迭代过程中改变了迭代器的状态,可能会得到意外结果,因为`sum()`不会再次遍历。 4. **默认值**:`sum(iterable[, start])`中的可选参数`start`,默认值为0,如果省略,函数将从0开始累加。如果预期从其他数开始,记得提供正确的初始值。 5. **递归错误**:对于非常大的数据集,如果内部递归太深,可能会导致RecursionError。这时应考虑是否应该改用循环或其他优化策略。 **相关问题--:** 1. `sum()`函数能处理哪些类型的序列? 2. 如何避免在`sum()`函数中因类型错误引发的异常? 3. 怎么处理`sum()`函数对空容器的响应以获取None而不是0?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值