黑马程序员——C基础---圆括号的使用总结

本文总结了C语言中圆括号的使用,包括在表达式上防止结果偏差,确保函数参数列表的正确性,以及在指针定义和使用中的应用。通过示例解释了如何避免宏定义和三目运算符的常见问题,强调了括号在提高代码可读性和避免语法错误中的重要性。

------- <a href="http://www.itheima.com" target="blank">android培训</a>、<a href="http://www.itheima.com" target="blank">java培训</a>、期待与您交流! ----------


圆括号是C语言中使用非常频繁的运算符

主要使用场合如下

<<1>>使用在表达式上(缺少括号的话可能会造成结果偏差)

主要体现在表达式的嵌套,以防表达式计算结果与预想有偏差,同时也提高代码可读性

例1  防止与预想结果有偏差 有参宏

#define SUM(a,b) a+a*b

int main(){

int a = 10;

a = SUM(a,a+2);

}

实际我们想要的结果是130,可现实结果确实112,所以宏定义可以改为 #define SUM(a,b) (a)+(a)*(b)

例2  提高代码可读性  三目运算符 

a>b?a:c>d?c:d  a>b?a(c>d?c:d)

<<2>使用在函数的参数列表上 (包括形参和实参缺少括号的话会报错)

例如主函数main函数 int main(int argh,const char * argv[])

<<3>>使用在某些指针定义和使用上

定义 (缺少括号会报错)
二维数组指针 数据类型 (*指针变量名称)[二位数组列数];
函数指针        类型说明符 (*指针变量名)(参数列表);
使用 (缺少括号会导致与结果偏差或报错)
结构体指针间接访问成员的值 (*结构体指针变量).成员名    


### 关于JavaWeb部门管理模块的实现方法 在JavaWeb开发中,部门管理是一个常见的功能需求。通常情况下,该功能涉及增删改查(CRUD)操作。以下是针对修改部门这一具体场景的设计思路和代码示例。 #### 数据库设计 假设有一个`department`表用于存储部门信息,其结构如下: | 字段名 | 类型 | 描述 | |--------------|-------------|----------------| | id | INT PRIMARY KEY | 主键 | | name | VARCHAR(100) | 部门名称 | | description | TEXT | 部门描述 | #### 后端逻辑实现 ##### 控制器层 (Controller) 控制器负责接收前端传来的数据并调用服务层处理业务逻辑。以下是一个基于Spring MVC框架的示例: ```java @RestController @RequestMapping("/departments") public class DepartmentController { @Autowired private DepartmentService departmentService; /** * 修改部门信息接口 */ @PutMapping("/{id}") public ResponseEntity<String> updateDepartment(@PathVariable Integer id, @RequestBody Department department) { try { department.setId(id); departmentService.updateDepartment(department); return ResponseEntity.ok("更新成功"); } catch (Exception e) { return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body("更新失败:" + e.getMessage()); } } } ``` 上述代码实现了通过RESTful API的方式提供修改部门的功能[^2]。 ##### 服务层 (Service) 服务层主要封装具体的业务逻辑,例如校验输入参数、调用DAO层等。 ```java @Service public class DepartmentService { @Autowired private DepartmentDao departmentDao; public void updateDepartment(Department department) throws Exception { if (department == null || department.getId() == null) { throw new IllegalArgumentException("部门ID不能为空"); } int result = departmentDao.updateById(department); if (result != 1) { throw new RuntimeException("未找到对应的部门记录"); } } } ``` 此处的服务层采用了简单的异常抛出机制来确保错误能够被及时捕获并反馈给客户端[^3]。 ##### DAO层 (Data Access Object) DAO层专注于与数据库交互的操作。这里可以借助MyBatis框架简化SQL语句编写过程。 ```xml <!-- MyBatis Mapper XML --> <update id="updateById" parameterType="com.example.model.Department"> UPDATE department SET name = #{name}, description = #{description} WHERE id = #{id} </update> ``` 以上XML片段展示了如何利用MyBatis动态替换占位符从而执行更新查询[^4]。 #### 前端页面展示 对于前端部分,可以通过HTML+JavaScript组合或者采用Vue.js/Angular这样的现代前端框架构建用户界面。下面给出一个基本的例子: ```html <form onsubmit="return saveChanges();"> <input type="hidden" id="deptId" value="${department.id}"> 名称:<input type="text" id="deptName" value="${department.name}"><br><br> 描述:<textarea id="deptDesc">${department.description}</textarea><br><br> <button type="submit">保存更改</button> </form> <script> function saveChanges() { var deptId = document.getElementById('deptId').value; var deptName = document.getElementById('deptName').value; var deptDesc = document.getElementById('deptDesc').value; fetch(`/departments/${deptId}`, { method: 'PUT', headers: { 'Content-Type': 'application/json' }, body: JSON.stringify({ name: deptName, description: deptDesc }) }).then(response => response.text()) .then(result => alert(result)); return false; // 阻止默认提交行为 } </script> ``` 此脚本允许管理员填写新的部门详情并通过AJAX请求发送至服务器进行持久化存储。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值