首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

c 语言中如何判断两个类型是否相同?

在其他高级语言中这个这个要求很容易满足,但在C语言标准中没有提供类型判断功能. 说到这儿,这话题好像应该结束了。...但是,这个问题的答案其实并不是绝对是NO,虽然C语言标准中并没有提供类型判断的能力,但不同的C编译器在实现时会根据需要对C语言提供扩展功能。比如GNU C(gcc)....gcc 通过内置函数(Built-in Function) __builtin_types_compatible_p为C语言提供了运行时的类型判断功能: 示例如下: #include #include void test(int x){ // 判断x是否为void类型 if(__builtin_types_compatible_p(typeof...void,因为__builtin_types_compatible_p是编译内置函数,所以直接在宏定义中调用,所以上面的判断可以定义成一个简单的函数宏 #define __type_is_void(expr

2.6K30

leetcode-551-Student Attendance Record I(判断是否出现连续几个相同字符)

要求判断是否某个学生能被奖励。 2、关于A的,很容易,遍历一遍字符串统计A出现次数,当次数大于1时,返回false,结束遍历。...关于L的,也不难,遍历一遍字符串,当碰到L时,判断下一个字符和再下一个字符是否均为L,如果满足,返回false,结束遍历(这里要注意边界条件,即下一个字符是否在字符串以内);如果不满足,那么继续处理下一个字符...这样写代码看起来更加“清爽”,判断是否出现了连续的几个相同字符,采用的是碰到其他字符就“清空”的方法。...而2中的方法,是碰到‘L’时继续判断下一个以及再下一个字符是否仍是'L'的方式,这种方法不需要引进countl的频繁计算。...这道题目给予的启示是:当要判断字符是否连续出现时,可以采用“清空”的方法来做。

60960
领券